首页 > 其他 > 详细

网络编程(socket)中的粘包处理

时间:2017-05-27 10:02:36      阅读:367      评论:0      收藏:0      [点我收藏+]

服务端

  

import socket,os

service=socket.socket()
service.bind((‘localhost‘,1024)) #绑定要监听的端口
service.listen()###监听端口
con,adder=service.accept()#等对方的连接,把对方的连接在本地生成一个实例并赋值个给con
while True:
data=con.recv(1024).decode(‘utf-8‘)##接收对方传过来的值(接收的最大值为2222个字节)并且赋值
x=os.popen(data).read()
con.send(str(len(x)).encode(‘utf-8‘))
#time.sleep(0.5) ###防止粘包,但是会有延迟(不推荐)
check_ack=con.recv(1024)##两次send之间在进行一次交互来防止粘包(推荐),同时在客户端也进行回应
con.send(x.encode(‘utf-8‘))#向对方发送数据
service.close()


客服端


 
import socket
client=socket.socket()
client.connect((‘localhost‘,1024))
while True:
msg=input(‘:‘).encode(‘utf-8‘)
client.send(msg)
datasize=client.recv(1024).decode(‘utf-8‘)
client.send("我收到了,可以传下面的内容了".encode())###客户端进行一次自动的确认
x=0

while x != int(datasize):
a=client.recv(1012).decode(‘utf-8‘)
x+=len(a)
print(a)
else:
print(datasize,x)
 

网络编程(socket)中的粘包处理

原文:http://www.cnblogs.com/ccnaie/p/6911246.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!