python3 解决tcp黏包方法一

Posted lilyxiaoyy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python3 解决tcp黏包方法一相关的知识,希望对你有一定的参考价值。

-------------------------------------------tcp_server.py-------------------------------------------
# coding:utf-8
import socket
import subprocess

server = socket.socket()
ip_port = ("127.0.0.1", 8001)
server.bind(ip_port)
server.listen(5)

conn, addr = server.accept()
from_client_msg = conn.recv(1024)
print("来自客户端的消息:", from_client_msg.decode("utf-8"))
cmd = input(">>>:").strip()
res = subprocess.Popen(
cmd,
shell=True,
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
)
cmd_result = res.stdout.read()
if res.stderr.read():
cmd_result = res.stderr.read()
cmd_result_len = len(cmd_result)
print(cmd_result_len)
conn.send(str(cmd_result_len).encode("utf-8")) # 先发送数据的长度
from_client_msg = conn.recv(1024)
if from_client_msg.decode("utf-8") == "recv_ready":
conn.sendall(cmd_result) # 再发送真实数据

conn.close()
server.close()



-------------------------------------------tcp_client.py-------------------------------------------



# coding:utf-8
import socket

client = socket.socket()
ip_port = ("127.0.0.1", 8001)
client.connect(ip_port)

client.send("我是客户端.".encode("utf-8"))
from_serve_msg = client.recv(1024) # 接收数据长度
print("来自服务端的消息:", from_serve_msg.decode("utf-8"))
if from_serve_msg.decode("utf-8").isdigit():
from_serve_msg_len = int(from_serve_msg)
client.send("recv_ready".encode("utf-8"))
from_serve_msg = client.recv(from_serve_msg_len) # 接收真实数据
recv_ready_len = len(from_serve_msg)
while from_serve_msg_len > recv_ready_len: # 如果真实数据一次没有接收完
from_serve_msg += client.recv(from_serve_msg_len) # 继续接收数据
recv_ready_len = len(from_serve_msg)

print("来自客户端的消息:", from_serve_msg.decode("gbk"))

client.close()

 

以上是关于python3 解决tcp黏包方法一的主要内容,如果未能解决你的问题,请参考以下文章

网络通信中TCP出现的黏包以及解决方法 socket 模拟黏包

tcp协议黏包问题的解决方式

黏包-黏包的成因解决方式及struct模块初识文件的上传和下载

网络TCp数据的传输设计(黏包处理)

自定义报头解决粘包问题

黏包问题的成因与解决方案