python基础-TCP协议和UDP协议
TCP协议是一种流式协议,UDP协议是一种数据包协议。
TCP和UDP是OSI模型中传输层的协议。TCP提供可靠的通信传输,而UDP则常被用于让广播和细节控制交给应用的通信传输。
TCP和UDP区别总结:
| TCP | UDP | |
|---|---|---|
| 是否连接 | 面向连接 | 无连接 |
| 传输可靠性 | 可靠 | 不可靠 |
| 应用场合 | 少量数据 | 大量数据 |
| 传输速度 | 慢 | 快 |
区别补充说明:
1、TCP提供可靠的服务,通过TCP连接传送的数据,无差错,不丢失,不重复,且按序到达;UDP尽最大努力交付,不保证可靠交付
2、TCP面向字节流,实际上是TCP把数据看成一连串无结构的字节流;UDP是面向报文的,UDP没有拥塞控制,因此网络出现拥塞不会使源主机的发送速率降低(对实时应用很有用,如IP电话,实时视频会议等)
3、每一条TCP连接只能是点到点的;UDP支持一对一,一对多,多对一和多对多的交互通信
4、TCP首部开销20字节;UDP的首部开销小,只有8个字
python编程步骤不同
TCP编程的服务器端一般步骤是:
import socket
# 步骤二的参数
from socket import SOL_SOCKET
from socket import SO_REUSEADDR
# TCP服务端
# 1、创建socket对象,通过socket()获取
server_socket = socket.socket()
# 2、设置socket属性,导入参数,通过setsockopt() #该步骤可选
server_socket.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
# 3、绑定IP地址、端口信息到socket对象中,通过bind(),参数是一个元组
server_socket.bind(('127.0.0.1', 9527))
# 4、开启半连接池,使用listen(),参数是整型,表示接收可等待的客户端
server_socket.listen(5)
while True:
# 5、阻塞状态,自动接收客户端的连接,通过函数accept(),返回连接对象和客户端地址
conn, client = server_socket.accept()
while True:
try:
# 6、收发数据,通过recv() 接收数据,默认参数是1024,表示每次接收数据最大字节数为1024;
re_data = conn.recv(1024).decode('utf-8')
# 获取到空数据后,重新收发数据
if len(re_data) == 0:
continue
# 获取到q后,关闭连接
if re_data == 'q':
break
print(re_data)
# send()发送数据,数据必须是bytes类型
msg = input("from server……").strip().encode('utf-8')
conn.send(msg)
except ConnectionResetError as e:
print(e)
# 7、关闭连接
conn.close()
# 8、关闭连接池
server_socket.close()
TCP编程的客户端一般步骤是:
import socket
# 步骤二的参数
from socket import SOL_SOCKET
from socket import SO_REUSEADDR
# TCP客户端
# 1、创建socket对象,通过socket()获取
client_socket = socket.socket()
# 2、设置socket属性,导入参数,通过setsockopt() #该步骤可选
client_socket.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
# 3、设置要连接的服务端的IP地址和端口属性并连接到服务端,通过connect()
# 参数为元组,元组中第一个元素是IP地址,第二个元素是端口号
client_socket.connect(('127.0.0.1', 9527))
while True:
# 4、通过send()发送数据,数据必须是bytes类型
msg = input('from client……').strip().encode('utf-8')
client_socket.send(msg)
# 5、通过recv() 接收数据,默认参数是1024,表示每次接收数据最大字节数为1024;
re_data = client_socket.recv(1024).decode('utf-8')
if re_data == 'q':
break
print(re_data)
# 6、关闭网络连接
client_socket.close()
UDP编程的服务端一般步骤是:
import socket
# 步骤二的参数
from socket import SOL_SOCKET
from socket import SO_REUSEADDR
# UDP服务端
# 1、获取socket对象,type=-1或者1 表示socket的类型默认为SOCK_STREAM ---→ TCP
# type = 2表示socket的类型为SOCK_DGRAM ----→ UDP
server = socket.socket(type=2)
# 2、设置socket属性,导入参数,通过setsockopt() #该步骤可选
server.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
# 3、绑定服务器地址和端口
server.bind(('127.0.0.1', 9527))
# 4、循环收发数据
while True:
# 自动阻塞,等待客户端访问,接收客户端发送数据,接收使用recvfrom()
# 收到的记录是一个元组,分别是数据和地址
data, addr = server.recvfrom(1024)
re_data = data.decode('utf-8')
if len(re_data) == 0:
continue
if re_data == 'q':
break
# 打印收到的结果
print(f'client_addr:{addr},re_data:{re_data}')
# 输入发送给client的记录
msg = input('from Server to Client:').strip().encode('utf-8')
# 发送消息使用sendto,参数是二进制数据和地址
server.sendto(msg, addr)
# 5、关闭网络连接
server.close()
UDP编程的客户端一般步骤是:
import socket
# 步骤二的参数
from socket import SOL_SOCKET
from socket import SO_REUSEADDR
# UDP服务端
# 1、获取socket对象,type=-1或者1 表示socket的类型默认为SOCK_STREAM ---→ TCP
# type = 2表示socket的类型为SOCK_DGRAM ----→ UDP
client = socket.socket(type=2)
# 2、设置socket属性,导入参数,通过setsockopt() #该步骤可选
client.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
server_add = '127.0.0.1' # 服务端地址
# 3、循环收发数据
while True:
# 发送数据使用sendto(),参数是二进制数据和地址
msg = input('from_udp_client……').strip().encode('utf-8')
client.sendto(msg, (server_add, 9527))
# 接收数据使用recvfrom()
re_data, addr = client.recvfrom(1024)
if re_data.decode('utf-8') == 'q':
break
print(re_data.decode('utf-8'))
# 4、关闭连接
client.close()
python基础-TCP协议和UDP协议的更多相关文章
- python语法基础-网络编程-TCP协议和UDP协议
############### 网络编程 ############## """ 网络编程 学习了Python基础之后,包括函数,面向对象等,你就可以开发了,你 ...
- python 全栈开发,Day33(tcp协议和udp协议,互联网协议与osi模型,socket概念,套接字(socket)初使用)
先来回顾一下昨天的内容 网络编程开发架构 B/S C/S架构网卡 mac地址网段 ip地址 : 表示了一台电脑在网络中的位置 子网掩码 : ip和子网掩码按位与得到网段 网关ip : 内置在路由器中的 ...
- TCP协议和UDP协议基础介绍
TCP协议和UDP协议区别 标签(空格分隔): TCP,udp TCP的三次握手 TCP被称为可靠的数据传输协议,主要是通过许多机制来实现的其中最主要的就是三次握手的功能,当然,TCP传送数据的机制非 ...
- (1)基于tcp协议的编程模型 (2)tcp协议和udp协议的比较 (3)基于udp协议的编程模型 (4)反射机制
1.基于tcp协议的编程模型(重中之重)1.1 编程模型服务器: (1)创建ServerSocket类型的对象,并提供端口号: (2)等待客户端的连接请求,调用accept()方法: (3)使用输入输 ...
- (1)网络编程的常识 (2)基于tcp协议的编程模型 (3)tcp协议和udp协议的比较 (4)基于udp协议的编程模型
1.网络编程的常识 目前主流的网络通讯软件有:微信.QQ.YY.陌陌.探探.飞信.阿里旺旺.... 在吗? 1.1 七层网络模型(熟悉) 为了保证数据传递的可靠安全等等,ISO(国际标准委员会组织)将 ...
- 采用tcp协议和UDP协议实现简单的聊天功能
Date: 2019-06-19 Author: Sun 一. Python3输出带颜色字体 实现过程: 终端的字符颜色是用转义序列控制的,是文本模式下的系统显示功能,和具体的语言无关. 转义 ...
- TCP协议和UDP协议的区别
1. TCP协议面向连接. UDP协议面向非连接 (有无链接)2. TCP协议传输速度慢. UDP协议传输速度快 (传输速度)3. TCP协议保证数据顺序. UDP协议不保证 (数据的有序性. 在IP ...
- TCP协议和UDP协议下的socket
UDP协议的服务端和客户端: ##udp_服务端 import socket udp_server = socket.socket(type=socket.SOCK_DGRAM)#选择udp协议 ip ...
- tcp协议和udp协议的使用场景
一:什么是TCP(Transmission Control Protocol,传输控制协议) tcp是面向连接的协议,也就是说,在收发数据前,必须和对方建立可靠的连接.一个TCP连接必须要经过三次 ...
随机推荐
- Eclipse 的快捷键
1. 代码折叠的快捷键,默认是: Ctrl+Shift+Numpad_Divede(小键盘的/号) Ctrl+Shift+Numpad_Multiply(小键盘的*号) 2.删除一行:Ctrl+D 3 ...
- Cesium区分单击【LEFT_CLICK】和双击事件【LEFT_DOUBLE_CLICK】
问题描述 在cesium中,用户鼠标左键双击视图或Entity时,实际触发的是两次click和一次dbclick事件,非常影响代码设计,本文记录了如何区分单击[LEFT_CLICK]和双击事件[LEF ...
- RDIFramework.NET敏捷开发框架WinForm新增文件中心-实现附件集中管理
1.引言 文件中心类似附件管理是一个非常实用功能,可以归档自己平时所需要的文件,也可以把文件分享给别人,更像一个知识中心.文件中心主界面如下图所示,左侧"附件分类"展示了用户对文件 ...
- easyui textbox setValue以及setText的使用技巧
1.先赋值Value,后赋值Text $('#Name').textbox('setValue', "11");$('#Name').textbox('setText', &quo ...
- 多个git合并,并保留log历史记录
面临的需求是:将多个git仓库作为一个单独目录,整合到一个新的git仓库中:并且保留历史记录. 1. 新建一个summary仓库 新建一个summary仓库,用于整合一系列git仓库. git clo ...
- 004 C/C++ 数据类型_类型别名
#include "stdio.h" #include "stdlib.h" //这里定义了一个结构体. struct MyStruct1 { int a; f ...
- last.jenkins 其他 一些知识点
时区不一致. jenkins的的时间和 系统时间不一致. 打开jenkins的[系统管理]---> [脚本命令行],在命令框中输入一下命令[时间时区设为 亚洲上海] System.setProp ...
- Java Web 学习(8) —— Spring MVC 之文件上传与下载
Spring MVC 之文件上传与下载 上传文件 表单: <form action="upload" enctype="multipart/form-data&qu ...
- windows golang安装golang.org/x/net text grpc
使用git # 吧$GOPATH替换成自己的GOPATH git clone https://github.com/golang/net.git $GOPATH\src\golang.org\x\ne ...
- ReactNative: ReactNative初始项目的结构
一.介绍 初学RN,一切皆新.在上篇中成功地创建并运行了一个React-Native项目,这个demo的基本结构都是系统已经创建好的,开发者在此结构下完成自己的开发即可.分别用Xcode和WebSto ...