1. TCP协议下的如何解决粘包问题

  TCP(transport control protocol 传输控制协议)  使用Nagle算法,将多次间隔较小且数据量小的数据,合并成大的数据块;接受端无法识别每条数据的边界,因此产生粘包现象。

"""
Server
"""
from socket import * back_log = 5
bufsize = 1024
ip_port = ('127.0.0.1', 8080) tcp_server = socket(AF_INET, SOCK_STREAM) # 数据流
tcp_server.bind(ip_port)
tcp_server.listen(back_log) while True:
print('服务端开始处理连接。。。')
conn, addr = tcp_server.accept()
print('客户端连接', conn)
print('客户端地址', addr)
while True:
try:
data = conn.recv(bufsize)
if not data:
break
print('接收到的数据', data)
conn.send(data.upper())
except Exception as e:
print(e)
break
"""
Client
"""
from socket import * bufsize = 1024
ip_port = ('127.0.0.1', 8080) tcp_client = socket(AF_INET, SOCK_STREAM)
tcp_client.connect(ip_port)
tcp_client.send('hello'.encode('utf-8'))
tcp_client.send('world'.encode('utf-8'))
response = tcp_client.recv(bufsize)
print('response is ==> ', response) # response is ==> b'HELLOWORLD'

解决思路:告知接收端数据长度,导入struct模块,将字节长度封装成4个字节发送给接收方;

服务端 =====》TCP实现远程操作命令

from socket import *
import subprocess,struct bufsize = 1024
back_log = 5
ip_port = ('127.0.0.1', 8080) tcp_server = socket(AF_INET, SOCK_STREAM)
tcp_server.bind(ip_port)
tcp_server.listen(back_log)
while True:
conn, addr = tcp_server.accept()
print('current connection', conn)
while True:
try:
cmd = conn.recv(bufsize)
if not cmd:
break
print('data from client', cmd) res = subprocess.Popen(cmd.decode('utf-8'), shell=True,
stderr=subprocess.PIPE,
stdin=subprocess.PIPE,
stdout=subprocess.PIPE)
cmd_res = res.stderr.read()
if not cmd_res:
cmd_res = res.stdout.read()
print('response is:', cmd_res) data_length = struct.pack('i', len(cmd_res))
conn.send(data_length)
conn.send(cmd_res)
except Exception as e:
print(e)
break
# conn.close()

客户端 ====》

from socket import *
import struct bufsize = 100
ip_port = ('127.0.0.1', 8080)
tcp_client = socket(AF_INET, SOCK_STREAM)
tcp_client.connect(ip_port) while True:
cmd = input('>>>> ').strip()
if not cmd:
continue
if cmd == 'quit':
break
tcp_client.send(cmd.encode('utf-8')) length_data = tcp_client.recv(4) length = struct.unpack('i', length_data)[0]
print(length)
response = b''
recsize = 0
while recsize < length:
response += tcp_client.recv(bufsize)
recsize = len(response)
# print('execute result is:', response) # 接受字节长度小于发送数据长度,产生粘包
print('execute result is:', response.decode('gbk'))
tcp_client.close()

2. TCP协议如何实现多个客户端连接(并发处理)

导入socketserver模块,实现ocketserver.BaseRequestHandler,重写 handle 方法

使用

ThreadingTCPServer,线程实现并发
import socketserver

class MyServer(socketserver.BaseRequestHandler):
def handle(self):
print('conn is', self.request) # conn
print('addr is', self.client_address) # addr while True:
try:
data = self.request.recv(1024)
if not data:
break
self.request.sendall(data.upper())
except Exception as e:
print(e)
break if __name__ == '__main__':
ip_port = ('127.0.0.1', 8080)
s = socketserver.ThreadingTCPServer(ip_port, MyServer)
s.serve_forever()


3. 基于UDP套接字

  UDP 与TCP 不同,使用socket时用的时 SOCK_DGRAM 数据报

  sendto()发送的是元组数据类型,包含数据以及连接

  recvfrom()接收的也是数据以及连接

服务端 ====》

from socket import *

ip_port = ('127.0.0.1', 8080)
buf_size = 1024 udp_server = socket(AF_INET, SOCK_DGRAM) # datagram 数据报
udp_server.bind(ip_port) while True:
data, addr = udp_server.recvfrom(buf_size)
print(data)
udp_server.sendto(data.upper(), addr)

客户端====》

from socket import *

ip_port = ('127.0.0.1', 8080)
buf_size = 1024 udp_client = socket(AF_INET, SOCK_DGRAM) # datagram 数据报 while True:
msg = input('==>: ').strip()
udp_client.sendto(msg.encode('utf-8'), ip_port)
response, addr = udp_client.recvfrom(buf_size)
print(response.decode('utf-8'))

Python中Socket编程(TCP、UDP)的更多相关文章

  1. python中socket编程

    一.网络协议 客户端/服务器架构 1.硬件C/S架构(打印机) 2.软件C/S架构(互联网中处处是C/S架构):B/S架构也是C/S架构的一种,B/S是浏览器/服务器 C/S架构与socket的关系: ...

  2. 3、linux下Socket编程-TCP/UDP

    1.什么是Socket 网络的 Socket数据传输是一种特殊的I/O,Socket也是一种文件描述符.Socket也具有一个类似于打开文件的函数调用Socket(),该函数返 回一个整型的Socke ...

  3. python day31--网络编程,tcp,udp的指令,及黏包

    一.TCP tcp中遇到黏包会让数据传输完. server import socket sk=socket.socket() sk.bind(('127.0.0.1',8090)) sk.listen ...

  4. Python中Socket编程server与client简单的合法性认证

    导入python自带的hmac模块对随机生成的位数32字节和自定义token进行加密处理 import osmsg = os.urandom(32)  #随机生成msgOut[4]: b"F ...

  5. python之socket编程(一)

    socket之前我们先来熟悉回忆几个知识点. OSI七层模型 OSI(Open System Interconnection)参考模型是国际标准化组织(ISO)制定的一个用于计算机或通信系统间互联的标 ...

  6. 网络编程—网络基础概览、socket,TCP/UDP协议

    网络基础概览 socket概览 socket模块—TCP/UDP的实现 TCP/UDP总结 网络基础概览 osi七层协议各层主要的协议 # 物理层传输电信号1010101010 # 数据链路层,以太网 ...

  7. Fixed-Length Frames 谈谈网络编程中应用层(基于TCP/UDP)的协议设计

    http://blog.sina.com.cn/s/blog_48d4cf2d0101859x.html 谈谈网络编程中应用层(基于TCP/UDP)的协议设计 (2013-04-27 19:11:00 ...

  8. 转:Python 的 Socket 编程教程

    这是用来快速学习 Python Socket 套接字编程的指南和教程.Python 的 Socket 编程跟 C 语言很像. Python 官方关于 Socket 的函数请看 http://docs. ...

  9. 操作系统底层原理与Python中socket解读

    目录 操作系统底层原理 网络通信原理 网络基础架构 局域网与交换机/网络常见术语 OSI七层协议 TCP/IP五层模型讲解 Python中Socket模块解读 TCP协议和UDP协议 操作系统底层原理 ...

随机推荐

  1. 【图像处理】OpenCV+Python图像处理入门教程(四)几何变换

    这篇随笔介绍使用OpenCV进行图像处理的第四章 几何变换. 4  几何变换 图像的几何变换是指将一幅图像映射到另一幅图像内.有缩放.翻转.仿射变换.透视.重映射等操作. 4.1  缩放 使用cv2. ...

  2. Get和Post区别(转载)

    转载自:https://www.cnblogs.com/logsharing/p/8448446.html GET和POST是HTTP请求的两种基本方法,要说它们的区别,接触过WEB开发的人都能说出一 ...

  3. The League of Sequence Designers Gym - 102460E

    题目链接:https://vjudge.net/problem/Gym-102460E 思路:求: 题目当中给了一段伪代码算法,仔细一看发现它是不会记录负数情况,所以与正确答案会有误差,现在题目给定K ...

  4. PTA 二叉树的层次遍历

    6-6 二叉树的层次遍历 (6 分)   本题要求实现给定的二叉树的层次遍历. 函数接口定义: void Levelorder(BiTree T); T是二叉树树根指针,Levelorder函数输出给 ...

  5. 【Linux学习笔记0】-虚拟机运行CentOS(VMware12+CentOS)

    目录 一,资源 二,VMware12安装 记录自己学习linux的过程.这将会是一个系列,本文是该系列的第一部分,主要记录虚拟机(VMware12)及对应操作系统(CentOS)的安装过程. 虚拟机( ...

  6. Linux基础之Shell与变量

    一.提出问题 在平时的工作中,我们经常会碰到设置环境的问题,例如将应用的执行路径添加到PATH中,方便程序的执行:在Linux中更多的时候是跟shell打交道,很多通过shell启动的应用或者服务都需 ...

  7. 封装Vue纵向表头左右结构的table表格

    我们前端开发人员在使用表格的过程中,大概率碰到的都是表格头部在表格的最上边,然后呈一行展示,紧接着就是表格的每一行的每一个单元格来展示具体内容的场景,很少会遇到表格的头部呈纵向一行展示,也就是说表格的 ...

  8. Scrapy 5+1 ——五大坑附送一个小技巧

    笔者最近对scrapy的学习可谓如火如荼,虽然但是,即使是一整天地学习下来也会有中间两三个小时的"无效学习",不是笔者开小差,而是掉进了深坑出不来. 在此,给各位分享一下作为一名S ...

  9. 墙裂推荐:这可能是CAP理论的最好现实解释

    这篇文章蓝本:http://ksat.me/a-plain-english-introduction-to-cap-theorem 经过小码甲意译.原创配图, 干到让你怀孕. 你可能经常听到CAP定理 ...

  10. Vue和Node.js交互之token

    博主最近工作的时候,公司后台使用的JAVA,在做登陆时总会传来一个token然后我存在了本地存储中或Vuex中,之后每一次请求把它带在请求头上,然后就好奇想要自己做一个后台服务器然后做一个完整的登陆的 ...