面向对象编程(UDP协议)
UDP协议
UDP 是User Datagram Protocol的简称, 中文名是用户数据报协议,是OSI(Open System Interconnection,开放式系统互联) 参考模型中一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务,IETF RFC 768是UDP的正式规范。UDP在IP报文的协议号是17。
服务端
'''
UDP 协议 又称 数据报协议 SOCK_DGRAM '''
from socket import * # 一般不这样做 会重名 但写socket可以这样写 因为要用到太多 会有大量的socket. server = socket(AF_INET,SOCK_DGRAM)
server.bind(('127.0.0.1',8080)) # IP和端口 要绑定 服务端固定的IP端口
# server.listen() # 不需要 挂起的链接数 udp 没连接 # server.accept() # 不需要 因为udp就没连接
# while True:
# conn,addr = server.accept() # 干连接循环的活 while True:
data,client_addr = server.recvfrom(1024)
print('客户端数据:',data) # 我要知道谁给我发的
'''
(b'data', ('127.0.0.1', 51182))
(b'hello', ('127.0.0.1', 51182))
'''
server.sendto(data.upper(),client_addr) server.close()
客户端
'''
udp 可以发空 数据报协议 说是发空,其实不是空 ,还有一个IP 端口的信息,发空时 带个端口信息
tcp:不是一一对应的
udp:是一一对应的 数据报 完整的
'''
from socket import * # 一般不这样做 会重名 但写socket可以这样写 因为要用到太多 会有大量的socket. client = socket(AF_INET,SOCK_DGRAM)
# server.bind('127.0.0.1',8080) # IP和端口 要绑定 服务端固定的IP端口
# server.listen() # 不需要 挂起的链接数 udp 没连接 # server.accept() # 不需要 因为udp就没连接
# while True:
# conn,addr = server.accept() # 干连接循环的活 while True:
msg = input('>>>:').strip() # udp 可以发空 收到一个空
# if not msg:continue
client.sendto(msg.encode('utf-8'),('127.0.0.1',8080)) # 明确的指定发给谁 因为没有连接了 data,server_addr = client.recvfrom(1024)
print('服务端返回的数据:',data,'服务端的地址:',server_addr)
server.close()
不会粘包的UDP
服务端
# -*- coding:utf-8 -*-
'''
UDP 协议 又称 数据报协议 SOCK_DGRAM
sendto recvfrom 一一对应 数据报协议 没有粘包问题 udp 数据不安全 有可能发送数据 > 1024 或者网络异常 数据没了
tcp: 数据一定要可靠
远程执行命令
下载文件
udp协议:
查询操作eg:互联网上 查询时间 ntp时间服务器 udp协议 eg:查域名 转成ip 端口 dns服务器走的就是udp协议 能保证查询效率高 数据虽然不可靠
ntp时间服务器 dns服务器 qq 都是udp
'''
# from socket import * # 一般不这样做 会重名 但写socket可以这样写 因为要用到太多 会有大量的socket.
#
# server = socket(AF_INET,SOCK_DGRAM)
# server.bind(('127.0.0.1',8080)) # IP和端口 要绑定 服务端固定的IP端口
#
# res1 = server.recvfrom(1024)
# print('第一次:',res1)
# res2 = server.recvfrom(1024)
# print('第二次:',res2) from socket import * # 一般不这样做 会重名 但写socket可以这样写 因为要用到太多 会有大量的socket. server = socket(AF_INET,SOCK_DGRAM)
server.bind(('127.0.0.1',8080)) # IP和端口 要绑定 服务端固定的IP端口 res1 = server.recvfrom(4)
print('第一次:',res1)
res2 = server.recvfrom(1024)
print('第二次:',res2)
客户端:
'''
udp 可以发空 数据报协议 说是发空,其实不是空 ,还有一个IP 端口的信息,发空时 带个端口信息
tcp:不是一一对应的
udp:是一一对应的 数据报 完整的额
'''
# from socket import * # 一般不这样做 会重名 但写socket可以这样写 因为要用到太多 会有大量的socket.
#
# client = socket(AF_INET,SOCK_DGRAM)
#
# client.sendto(b'hello',('127.0.0.1',8080))
# client.sendto(b'world',('127.0.0.1',8080))
# client.close() from socket import * # 一般不这样做 会重名 但写socket可以这样写 因为要用到太多 会有大量的socket. client = socket(AF_INET,SOCK_DGRAM) client.sendto(b'hello',('127.0.0.1',8080))
client.sendto(b'world',('127.0.0.1',8080))
client.close()
TCP VS UDP
tcp基于链接通信
- 基于链接,则需要listen(backlog),指定连接池的大小
- 基于链接,必须先运行的服务端,然后客户端发起链接请求
- 对于mac系统:如果一端断开了链接,那另外一端的链接也跟着完蛋recv将不会阻塞,收到的是空(解决方法是:服务端在收消息后加上if判断,空消息就break掉通信循环)
- 对于windows/linux系统:如果一端断开了链接,那另外一端的链接也跟着完蛋recv将不会阻塞,收到的是空(解决方法是:服务端通信循环内加异常处理,捕捉到异常后就break掉通讯循环)
- 流式协议 会粘包 不可以发空 send recv 不是 一 一对应
- tcp适用于:
- 数据一定要可靠
- 远程执行命令
- 下载文件
udp无链接
- 无链接,因而无需listen(backlog),更加没有什么连接池之说了
- 无链接,udp的sendto不用管是否有一个正在运行的服务端,可以己端一个劲的发消息,只不过数据丢失
- recvfrom收的数据小于sendto发送的数据时,在mac和linux系统上数据直接丢失,在windows系统上发送的比接收的大直接报错
- 只有sendto发送数据没有recvfrom收数据,数据丢失
- 数据报协议 不会粘包 可以发空 sendto recvfrom 一 一 对应 数据报协议 数据不安全 有可能发送数据 > 1024 或者网络网络异常 数据没了
- udp适用于
- 查询操作 eg: ntp时间服务器 dns服务器(查域名,转ip) 能保证查询效率高,数据虽然不可靠
-------------------------------------------------------------
考核:
socket 通信 server client
定义一个学生类
元类? 使用元类定义一个对象
粘包
3次握手
封装 继承 多态
面向对象编程(UDP协议)的更多相关文章
- 网络编程 - UDP协议
UDP协议 服务端 ''' UDP 协议 又称 数据报协议 SOCK_DGRAM ''' from socket import * # 一般不这样做 会重名 但写socket可以这样写 因为要用到太多 ...
- 网络编程——UDP协议和通信
第1章 UDP与TCP协议 在介绍TCP/IP结构时,提到传输层的两个重要的高级协议,分别是UDP和TCP,其中UDP是User Datagram Protocol的简称,称为用户数据报协议,TCP是 ...
- 网络编程 UDP协议 TCP局域网客户端与服务端上传下载电影示例
UDP协议 (了解) 称之为数据包协议,又称不可靠协议. 特点: 1) 不需要建立链接. 2) 不需要知道对方是否收到. 3) 数据不安全 4) 传输速度快 5)能支持并发 6) 不会粘包 7) 无需 ...
- Java网络编程(UDP协议:接收端)
package WebProgramingDemo; import java.io.IOException; import java.net.DatagramPacket; import java.n ...
- Java网络编程(UDP协议:发送端)
package WebProgramingDemo; import java.io.IOException; import java.net.DatagramPacket; import java.n ...
- 网络Socket编程UDP协议例子
服务端代码 public class UDPChatServer { //通讯端口 private Integer port=8000; //数据报文的通讯通道对象 private DatagramC ...
- Java网络编程(UDP协议-聊天程序)
接收端: package WebProgramingDemo; import java.net.DatagramPacket; import java.net.DatagramSocket; publ ...
- udp协议基础(转自疯狂java讲义)
第17章 网络编程 17.4 基于UDP协议的网络编程 UDP协议是一种不可靠的网络协议,它在通信实例的两端各建立一个Socket,但这两个Socket之间并没有虚拟链路,这两个Socket只是发 ...
- 网络编程----socket介绍、基于tcp协议的套接字实现、基于udp协议的套接字实现
一.客户端/服务器架构(C/S架构) 即C/S架构,包括: 1.硬件C/S架构(打印机) 2.软件C/S架 ...
随机推荐
- 技术选型关于redis客户端选择
redis作为分布式缓存框架的首选 相信已经毋庸置疑.能高效.合理的使用好它 必定能提升系统的可用性,高性能.高吞吐量的保障.但选择一个客户端,充分发挥它的能力,就是一个选型问题.现在市场上能选择 ...
- druid监控
1 @ConfigurationProperties(prefix = "spring.datasource") 2 @Bean 3 public DataSource druid ...
- 新建表后,在sqlserver manager中使用显示引用对象无效
编辑>intelliSense(I)>刷新本地缓存.
- 数据仓库组件:Hive环境搭建和基础用法
本文源码:GitHub || GitEE 一.Hive基础简介 1.基础描述 Hive是基于Hadoop的一个数据仓库工具,用来进行数据提取.转化.加载,是一个可以对Hadoop中的大规模存储的数据进 ...
- Beta冲刺——第七天
这个作业属于哪个课程 https://edu.cnblogs.com/campus/fzzcxy/2018SE1 这个作业要求在哪里 https://edu.cnblogs.com/campus/fz ...
- 最开始的总结——JAVA
<最开始的总结> 回答自己几个问题:为什么去学它?学它有什么用?怎样去学它?自己目前目标是什么?估计自己会花多长时间去学习这些? 一.为什么学习Java,它有什么用? 答:我看中的是Jav ...
- springboot集成轻量级权限认证框架sa-token
sa-token是什么? sa-token是一个JavaWeb轻量级权限认证框架,主要解决项目中登录认证.权限认证.Session会话等一系列由此衍生的权限相关业务.相比于其他安全性框架较容易上手. ...
- springboot源码解析-管中窥豹系列之aware(六)
一.前言 Springboot源码解析是一件大工程,逐行逐句的去研究代码,会很枯燥,也不容易坚持下去. 我们不追求大而全,而是试着每次去研究一个小知识点,最终聚沙成塔,这就是我们的springboot ...
- MySQL中的全局锁和表级锁
全局锁和表锁 数据库锁设计的初衷是解决并发出现的一些问题.当出现并发访问的时候,数据库需要合理的控制资源的访问规则.而锁就是访问规则的重要数据结构. 根据锁的范围,分为全局锁.表级锁和行级锁三类. 全 ...
- Android事件分发机制一:事件是如何到达activity的?
事件分发,真的一定从Activity开始吗? 前言 很高兴遇见你~ 事件分发,android中一个老生常谈的话题了.基本的流程我们也都知道是从Activity开始分发,但有一个关键问题是:事件是如何到 ...