网络编程——TCP协议、UDP协议、socket套接字、粘包问题以及解决方法

TCP协议(流式协议)

​ 当应用程序想通过TCP协议实现远程通信时,彼此之间必须先建立双向通信通道,基于该双向通道实现数据的远程交互,该双向通道直到任意一方主动断开才会失效

TCP协议的“三次握手” 和 “四次挥手”

三次握手 建连接

​ 1、客户端向服务端发送建立连接请求

​ 2、服务端返回收到请求信息,同时向客户端发送连接请求

​ 3、客户端接收到服务端发来的请求,返回连接成功给服务端,完成双向连接

建立好连接后,会有一个反馈机制

​ 客户端往服务器发送请求,服务端必须返回响应,告诉客户端收到请求了,并且将服务端的数据一并返回给客户端

​ C ----> S :一次请求,必须有一次响应

优点

​ 数据安全

缺点

​ ①:传输速度慢

​ ②:洪水攻击

​ 指的是通过伪造大量的请求,往对方服务器发送请求,导致对方服务器响应跟不上,以至于瘫痪

​ 半连接池listen:限制用户在同一个时间段内的访问数量

四次挥手 断连接

​ 1、客户端向服务端发送断开连接的请求

​ 2、服务端返回接收到请求的信息给客户端

​ 3、服务端确认所有数据接收完成以后,再发送同意断开连接的请求给客户端

​ 4、客户端返回收到断开连接的请求,给服务端

UDP协议

UDP协议也被称之为数据包协议

UDP协议的特点:

​ ①:不需要建立连接

​ ②:不需要知道对方是否收到

​ ③:数据不安全,会丢包

​ ④:传输速度快

​ ⑤:能支持并发

​ ⑥:不会粘包

​ ⑦:无需先启动服务端再启动客户端

UDP的优点:

​ ①:传输速度快

​ ②:能支持并发

​ ③:不会粘包

UDP的缺点:(致命缺点)

数据不安全,容易丢失

UDP的应用场景:早期的QQ聊天室

socket套接字通信

什么是socket?

socket是一个模块,又称套接字,用来封装互联网协议(应用层以下的层)

为什么要有socket?

socket可以实现互联网协议应用层以下的层 的工作

提高开发效率

怎么使用socket?

# server.py文件
import socket
sever = socket.socket()
sever.bind(("127.0.0.1", 9527))
# 半连接池
sever.listen(5) # 最多接受5个客户端发送的请求,实际上是6个
# conn:指的是服务端网客户端的通道
coon, addr = sever.accept()
# 接收客户端发送过来的消息
ret = coon.recv(1024) # 一次可接受1024bytes的数据
print(ret)
# 关闭服务器
coon.close()
# client.py文件
"""
启动服务器后再启动客户端
"""
import socket client = socket.socket() client.connect(("127.0.0.1", 9527))
# 必须发送bytes类型的数据
# # 方式一
# client.send('hello'.encode('utf-8'))
# 方式二
client.send(b'hello')

粘包问题

TCP粘包是指发送方发送的若干包数据到接收方接收时粘成一包,从接收缓冲区看,后一包数据的头紧接着前一包数据的尾。

问题一:无法确认对方发送过来数据的大小

问题二:在发送数据时间隔短并且数据量小的情况下,会将所有数据一次性发送

解决方法: 确认对方的数据的大小

解决粘包问题(struct模块)

struct模块是什么?

是一个Python内置的模块,它可以将固定长度的数据,打包成固定格式的长度

常用的模式:i 模式

struct模块作用

​ 可以将真实数据,做成一个固定长度的报头,客户端发送给服务器,服务器可以接收报头,然后对报头进行解包,获取真实数据的长度,进行接收即可

import struct

data = b'11111111111111'
print(len(data))
# 打包制作报头
header = struct.pack('i', len(data))
print(header)
print(len(header)) # 解包获取真实数据长度 ---> 得到一个元组,元组中第一个值是真实数据的长度
res = struct.unpack('i', header)[0]
print(res)

扩展例题

# srever.py文件
import socket
import struct
import subprocess server = socket.socket()
server.bind(("127.0.0.1", 9527)) server.listen(5) while True: coon, addr = server.accept()
print(addr) while True:
try:
# 获取客户端传来的报头
header = coon.recv(4)
# 解包获取真实数据长度
data_len = struct.unpack('i', header)[0] # 准备接收真实数据
cmd = coon.recv(data_len) if len(cmd) == 0:
continue cmd = cmd.decode('utf-8')
if cmd == "q":
break obj = subprocess.Popen(
cmd, shell=True,
stdout=subprocess.PIPE,
stderr=subprocess.PIPE
) result = obj.stdout.read() + obj.stderr.read() print("发送给客户端的真实数据长度为", len(result)) header = struct.pack('i', len(result))
print(len(header))
coon.send(header)
coon.send(result) except Exception as e:
print(e)
break coon.close()
# client.py文件
import struct
import socket client = socket.socket()
client.connect(("127.0.0.1", 9527)) while True:
cmd = input("客户端输入的内容>>>:") cmd_bytes = cmd.encode('utf-8') # 做一个报头
header = struct.pack("i", len(cmd_bytes))
print(len(header)) client.send(header) # 待服务器确认长度后,发送真实数据长度
client.send(cmd_bytes) # 接收服务端返回的报头
header = client.recv(4) # 解包,接收服务端返回的真实数据
data_len = struct.unpack('i', header)[0]
result = client.recv(data_len) print("接收服务端返回的真实数据长度为:", len(result))
print(result.decode('gbk'))

网络编程——TCP协议、UDP协议、socket套接字、粘包问题以及解决方法的更多相关文章

  1. python 网络编程 tcp和udp 协议

    1. 网络通信协议 osi七层,tcp\ip五层 tcp\ip五层 arp协议:通过IP地址找到mac地址 2.tcp和udp的区别 tcp协议:面向连接,消息可靠,相对udp来讲,传输速度慢,消息是 ...

  2. ~~网络编程(四):socket套接字~~

    进击のpython ***** 网络编程--socket socket的中文意思叫做套接字,socket方法其实也叫套接字方法 我们研究过TCP/UDP协议,但是要是让我们自己搭建,就十分困难了 而这 ...

  3. PHP Socket(套接字连接)扩展简介和使用方法

    PHP socket扩展是基于流行的BSD sockets,实现了和socket通讯功能的底层接口,它可以和客户端一样当做一个socket服务器. 使用这些函数时请注意,虽然他们中有很多和C函数同名的 ...

  4. 网络编程 TCP协议:三次握手,四次回收,反馈机制 socket套接字通信 粘包问题与解决方法

    TCP协议:传输协议,基于端口工作 三次握手,四次挥手 TCP协议建立双向通道. 三次握手, 建连接: 1:客户端向服务端发送建立连接的请求 2:服务端返回收到请求的信息给客户端,并且发送往客户端建立 ...

  5. Socket网络编程TCP、UDP演示样例

    Socket网络编程: 1) OSI(了解): 国际标准化组织ISO(International Orgnization for Standardization)指定了网络通信的模型:开放系统互联(O ...

  6. tcp套接字粘包解决办法

    粘包只会出现在tcp,udp传输不会产生粘包现象.解决粘包的原理就是服务器预先向客户端发送客户端即将获取文件的大小. 第一版解决方案: 服务器: # Author : Kelvin # Date : ...

  7. 网络编程之基于UDP协议的套接字编程、基于socketserver实现并发的socket

    目录 基于UDP协议的套接字编程 UDP套接字简单示例 服务端 客户端 基于socketserver实现并发的socket 基于TCP协议 server类 request类 继承关系 服务端 客户端1 ...

  8. python 之 网络编程(基于UDP协议的套接字通信)

    8.5 基于UDP协议的套接字通信 UDP协议:数据报协议 特点:无连接,一发对应一收,先启动哪一端都不会报错 优点:发送效率高,但有效传输的数据量最多为500bytes 缺点:不可靠:发送数据,无需 ...

  9. Linux 网络编程五(UDP协议)

    UDP和TCP的对比 --UDP处理的细节比TCP少. --UDP不能保证消息被传送到目的地. --UDP不能保证数据包的传递顺序. --TCP处理UDP不处理的细节. --TCP是面向连接的协议 - ...

随机推荐

  1. mysql数据库之忘记root密码

    1.  vi /etc/my.cnf,在[mysqld]中添加 skip-grant-tables 例如: [mysqld] skip-grant-tables datadir=/var/lib/my ...

  2. 两种方式实现浅拷贝 for in实现和Object.assign({}, 对象1, 对象2);

    浅拷贝只拷贝对象的一层,如果对象的属性还是对象,那么user3和user4这两个对象对应的值都会发生改变 // 拷贝分为浅拷贝和深拷贝. // 浅拷贝的实现 通过for in实现 var user1 ...

  3. python 函数,模块知识点运用示例

    给定验证码长度n,生成随机验证码,验证码由数字.字母组成(参考chr()内置方法) # 给定验证码长度n,生成随机验证码,验证码由数字.字母组成(参考chr()内置方法) # 第33-126号(共94 ...

  4. oracle查看被锁的表及解除锁

    -- 查看被锁对象 select object_name,machine,s.sid,s.serial# from v$locked_object l,dba_objects o ,v$session ...

  5. IDEA中的模板文件设置

    idea中的设置 Settings>Editor>File and code Templates>Includes>File Header 中粘贴下面的表达格式 /** * @ ...

  6. LG2598/BZOJ1412 「ZJOI2009」狼和羊的故事 最小割

    问题描述 LG2598 BZOJ1412 题解 看到要把狼和羊两个物种分开 自然想到最小割. 发现\((x,y)\)可以向上下左右走以获得贡献,所以建边:\((x,y),(x-1,y)\),\((x, ...

  7. 批处理命令 call

    call 命令 CALL命令可以在批处理执行过程中调用另一个批处理,当另一个批处理执行完后,再继续执行原来的批处理 CALL command 调用一条批处理命令,和直接执行命令效果一样,特殊情况下很有 ...

  8. [POJ1189][BZOJ1867][CODEVS1709]钉子和小球

    题目描述 Description 有一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1).每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且 ...

  9. dl-google.com 的问题

    印象里,如果用过公司vpn之后,再用android studio, 这个地址就能被解析下载了. 看来,应该只是域名被屏蔽,ip并没有. 所以,以后拿到ip之后,写进hosts里应该没事 https:/ ...

  10. echarts的markline的使用 y轴预警线

    代码示例: app.title = '坐标轴刻度与标签对齐'; option = { color: ['#3398DB'], tooltip : { trigger: 'axis', axisPoin ...