粘包只会出现在tcp,udp传输不会产生粘包现象。解决粘包的原理就是服务器预先向客户端发送客户端即将获取文件的大小。

第一版解决方案:

服务器:

 # Author : Kelvin
# Date : 2019/2/2 17:38
from socket import *
import subprocess ip_conf = ("127.0.0.1", 8888)
buffer_capacity = 1024
tcp_server = socket(AF_INET, SOCK_STREAM)
tcp_server.bind(ip_conf)
tcp_server.listen(5)
while True:
conn, addr = tcp_server.accept()
while True:
try:
cmd = conn.recv(buffer_capacity) # 如果强制断开连接会触发try,try正是解决强制中断连接的问题
print("收到的cmd:%s" % cmd)
if not cmd: # 如果使用quit断开连接,服务器会死循环收到空,该判断正是解决此问题
break
res = subprocess.Popen(cmd.decode("utf8"), shell=True, stdout=subprocess.PIPE, stdin=subprocess.PIPE,
stderr=subprocess.PIPE)
err = res.stderr.read()
if err:
back_msg = err
else:
back_msg = res.stdout.read()
if not back_msg:
back_msg = "acute successful!".encode("gbk")
length = len(back_msg)
conn.send(str(length).encode("gbk"))
re_ready = conn.recv(buffer_capacity).decode("utf8")
if re_ready == "ready":
conn.send(back_msg)
except Exception as e:
print(e)
break
tcp_server.close()

客户端:

 # Author : Kelvin
# Date : 2019/2/2 17:38
from socket import * ip_conf = ("127.0.0.1", 8888)
buffer_capacity = 1024
tcp_client = socket(AF_INET, SOCK_STREAM)
tcp_client.connect(ip_conf)
while True:
cmd = input("Please input cmd : ")
if not cmd:
continue
if cmd == "quit":
break
tcp_client.send(cmd.encode("utf8"))
re_size = int(tcp_client.recv(buffer_capacity).decode("utf-8"))
print("大小:", re_size)
tcp_client.send("ready".encode("utf8"))
recved_size = 0
recved_data = b""
while recved_size < re_size:
recved_data += tcp_client.recv(buffer_capacity)
recved_size = len(recved_data)
back_msg = recved_data.decode("gbk")
print(back_msg)
tcp_client.close()

升级版:

服务器:

 # Author : Kelvin
# Date : 2019/2/2 17:38
from socket import *
import subprocess
import struct ip_conf = ("127.0.0.1", 8888)
buffer_capacity = 1024
tcp_server = socket(AF_INET, SOCK_STREAM)
tcp_server.bind(ip_conf)
tcp_server.listen(5)
while True:
conn, addr = tcp_server.accept()
while True:
try:
cmd = conn.recv(buffer_capacity) # 如果强制断开连接会触发try,try正是解决强制中断连接的问题
print("收到的cmd:%s" % cmd)
if not cmd: # 如果使用quit断开连接,服务器会死循环收到空,该判断正是解决此问题
break
res = subprocess.Popen(cmd.decode("utf8"), shell=True, stdout=subprocess.PIPE, stdin=subprocess.PIPE,
stderr=subprocess.PIPE)
err = res.stderr.read()
if err:
back_msg = err
else:
back_msg = res.stdout.read()
if not back_msg:
back_msg = "acute successful!".encode("gbk")
length = len(back_msg)
re_length = struct.pack("i", length)
conn.send(re_length)
conn.send(back_msg)
except Exception as e:
print(e)
break
tcp_server.close()

客户端:

 # Author : Kelvin
# Date : 2019/2/2 17:38
from socket import *
import struct
ip_conf = ("127.0.0.1", 8888)
buffer_capacity = 1024
tcp_client = socket(AF_INET, SOCK_STREAM)
tcp_client.connect(ip_conf)
while True:
cmd = input("Please input cmd : ")
if not cmd:
continue
if cmd == "quit":
break
tcp_client.send(cmd.encode("utf8"))
re_size = struct.unpack("i",tcp_client.recv(4))[0]
print("大小:", re_size)
recved_size = 0
recved_data = b""
while recved_size < re_size:
recved_data += tcp_client.recv(buffer_capacity)
recved_size = len(recved_data)
back_msg = recved_data.decode("gbk")
print(back_msg)
tcp_client.close()

最新文章

  1. 数据库Sharding系列文章
  2. Eclipse设置风格
  3. 荒芜的周六-PHP之面向对象(三)
  4. 解决Cannot find MySQL header files under /usr/include/mysql的错误
  5. 通过j-interop访问WMI实例代码
  6. 详解Bootstrap导航组件
  7. php生成excel文件的简单方法
  8. hibernate CascadeType属性说明
  9. AVG()和to_date()函数的使用
  10. spm使用之六安装别人写好的spm文档主题模板
  11. python遗传算法实现数据拟合
  12. MyBaits 错误分析
  13. GO开发[三]:fmt,strings,strconv,指针,控制结构
  14. 「拆小鹤」使用 python 实现 QQ机器人服务。
  15. Oracle11g 体系结构
  16. 四种常见的 POST 提交数据方式对应的content-type取值
  17. vector的多套遍历方案
  18. RHEL yum
  19. vue input,textarea失去焦点调用函数方法
  20. 前端开发 - HTML/CSS

热门文章

  1. 简述Action+Service +Dao 功能
  2. lvs与nginx区别
  3. YOLO_Online 将深度学习最火的目标检测做成在线服务实战经验分享
  4. javascript 用函数语句和表达式定义函数的区别详解
  5. 深入理解SpringBoot之自动装配
  6. 用Laravel Sms实现 laravel短信验证码的发送
  7. ImportError: numpy.core.multiarray failed to import
  8. 原生javascript写自己的运动库(匀速运动篇)
  9. MySql的下载和安装(解压版)
  10. 爬虫-Python爬虫常用库