Files
tcp_port_tran/target_client.py

194 lines
4.8 KiB
Python
Raw Normal View History

import os
import sys
import json
import socket
import threading
import time
import prot_codec as pc
# tcp 客户端脚本
# 一个本地服务端
# 一个远程客户端
_LOCAL_PORT = 31234
_remote_client=None
_local_client=[]
_local_server=None
2024-10-08 20:29:52 +08:00
_log_fp=None
def _time():
return '['+time.strftime("%Y-%m-%d %H:%M:%S")+']'
def myprint_dec(func):
def wrapper(*args, **kwargs):
# 在这里添加额外的功能
# print(_time(), str(e),file=_log_fp)
kwargs["file"]=_log_fp
result = func(_time(),*args, **kwargs)
_log_fp.flush()
return result
return wrapper
myprint=myprint_dec(print)
# 发送数据到指定ip地址和端口
def send_to(ip,port,data:bytearray):
for item in _local_client:
if(item[1]==ip and item[2]==port):
2024-10-08 20:29:52 +08:00
myprint(f"recv from remote {ip},{port}")
item[0].send(data)
return
2024-10-08 20:29:52 +08:00
myprint(f"can not fond {ip},{port}")
# 关闭指定地址的端口
def close(ip,port):
for item in _local_client:
if(item[1]==ip and item[2]==port):
2024-10-08 20:29:52 +08:00
myprint(f'remote close {ip},{port}')
item[0].close()
2024-10-08 20:29:52 +08:00
_local_client.remove(item)
break
# 关闭所有
def close_all():
for item in _local_client:
item[0].close()
2024-10-08 20:29:52 +08:00
_local_client=[]
myprint('remote close all')
# 远端数据处理,解包,把负载数据发送到本地服务器
2024-10-08 20:29:52 +08:00
# 这个线程只会创建一个,用于连接代理服务器
def remote_client_handler(tcp_remote:socket):
global _remote_client
global _local_client
global _local_server
2024-10-08 20:29:52 +08:00
myprint("已连接代理服务器")
recv_data=bytearray()
cmd={'device':'client','option':'login'}
data=pc.encode(json.dumps(cmd).encode('utf-8'),b'default')
_remote_client.send(data)
while True:
try:
recv = tcp_remote.recv(4096)
except Exception as e:
2024-10-08 20:29:52 +08:00
myprint("remote:",str(e))
break
if recv:
recv_data+=recv
while True:
start=recv_data.find(b'\xff')
end=recv_data.find(b'\xfe')
if(start==-1 or end==-1):
break
cmd,data=pc.decode(recv_data[start:end+1])
2024-10-08 20:29:52 +08:00
myprint(cmd.decode('utf-8'))
try:
j=json.loads(cmd)
if(j['device']=='server'):
if(j['option']=='data'):
send_to(j['ip'],j['port'],data)
elif(j['option']=='disconnect'):
close(j['ip'],j['port'])
elif(j['device']=='proxy'):
if(j['option']=='close'):
close_all()
except Exception as e:
2024-10-08 20:29:52 +08:00
myprint(str(e))
recv_data=recv_data[end+1:]
else:
break
tcp_remote.close()
2024-10-08 20:29:52 +08:00
myprint("proxy close")
2024-10-08 18:46:04 +08:00
close_all()
if _local_server is not None:
_local_server.close()
# 本地数据处理,解包,把负载数据发送到本地服务器
2024-10-08 20:29:52 +08:00
# 每个本地连接都会创建一个线程
def local_client_handler(tcp_server:socket,addr):
global _remote_client
global _local_client
2024-10-08 20:29:52 +08:00
myprint("addr:",addr)
addr_info=(tcp_server,addr[0],addr[1])
_local_client.append(addr_info)
if(_remote_client is not None):
cmd={'device':'client','option':'connect','ip':addr[0],'port':addr[1]}
data=pc.encode(json.dumps(cmd).encode('utf-8'),b'default')
_remote_client.send(data)
while True:
try:
recv = tcp_server.recv(4096)
except Exception as e:
2024-10-08 20:29:52 +08:00
myprint("local:",str(e))
break
if recv:
cmd={'device':'client','option':'data','ip':addr[0],'port':addr[1]}
data=pc.encode(json.dumps(cmd).encode('utf-8'),recv)
if _remote_client is not None:
_remote_client.send(data)
2024-10-08 20:29:52 +08:00
myprint(f"send to remote {addr[0]},{addr[1]}")
else:
break
tcp_server.close()
if(_remote_client is not None):
cmd={'device':'client','option':'disconnect','ip':addr[0],'port':addr[1]}
data=pc.encode(json.dumps(cmd).encode('utf-8'),b'default')
2024-10-08 18:46:04 +08:00
try:
_remote_client.send(data)
except Exception as e:
2024-10-08 20:29:52 +08:00
myprint("remote close",str(e))
_local_client.remove(addr_info)
def main():
global _remote_client
global _local_client
global _local_server
_remote_client = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
_remote_client.connect(("1.92.113.30",5345))
thd = threading.Thread(target = remote_client_handler, args = (_remote_client,))
thd.start()
_local_server = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
_local_server.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,True)
_local_server.bind(("",_LOCAL_PORT))
2024-10-08 20:29:52 +08:00
myprint(f"开始监听({_LOCAL_PORT})")
_local_server.listen(128)
while True:
try:
temp , temp_address = _local_server.accept()
except Exception as e:
2024-10-08 20:29:52 +08:00
myprint("local server:",str(e))
break
thd = threading.Thread(target = local_client_handler, args = (temp,temp_address))
thd.start()
if __name__ == "__main__":
2024-10-08 20:29:52 +08:00
_log_fp=open("target_client.log",mode="w+",encoding="utf-8")
main()