~~网络编程(八):UDP~~
进击のpython
*****
网络编程——UDP
那现在看到这里的
这就是网络编程的最后一讲了
上面讲的都是关于TCP的编程方法
还记得TCP和UDP传输的区别吗?
UDP简单就简单到它可以不借助管道来进行数据的传输
那要怎那么通过套接字方法来进行UDP方式的信息传输呢?
老规矩,信息收发创建两个py文件,服务端和客户端
server = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
还记得这句话在TCP怎么写的吧
在这里数据传输方式用的是“数据报模式”,所以UDP协议也叫数据报协议
(phone = socket.socket(socket.AF_INET, socket.SOCK_STREAM))
在这就要讲了,流式协议是不是有粘包现象啊
不好意思熬,在UDP这根本就没有这个现象
我们发现这个socket.socket每次都写很麻烦
所以我们可以在开始导入模块的时候这么写
form socket import *
虽然说不建议用*来导入模块,但是由于我们要使用的方法太多了
所以说,就可以对这个模块全部导入
所以上面的方法就可以写成
server = socket(socket.AF_INET,socket.SOCK_DGRAM)
那什么绑定端口,绑定IP,是不是都需要?
server.bind(("127.0.0.1", 8080))
那需不需要监听呢?server.listen(5)
我这是UDP,有链接嘛?是不是没有?所以不需要监听
那需不需要server.accept()呢?
还是这句话,accept是为了链接才使用的,我UDP没有链接,所以也不要
那没有链接,是不是不需要链接循环了啊
那通信循环是不是还应该要啊
在UDP中,收消息叫 recvfrom() 发消息用 sendto()
while 1:
data = server.recvfrom(1024)
print(data)
server.close()
那服务端就写完了
接下来就是客户端了
客户端需不需要绑定IP? 当然不需要!
客户端需不需要建立管道?当然不需要!
那我能不能发送空呢?
对于TCP来说是不能的,那看看UDP呢
msg = input(">>>")
client.sendto(msg.encode("utrf-8"),("127.0.0.1", 8080))
sendto接收两个参数,第一个是你发送的信息,第二个是你要发给的ip和端口号的元组形式
那,客户端和服务端就写完了
# 客户端
from socket import *
client = socket(AF_INET, SOCK_DGRAM)
while 1:
msg = input(">>>")
client.sendto(msg.encode("utf-8"), ("127.0.0.1", 8080))
client.close()
# 服务端
from socket import *
server = socket(AF_INET, SOCK_DGRAM)
server.bind(("127.0.0.1", 8080))
while 1:
data = server.recvfrom(1024)
print(data)
server.close()
# 客户端
>>>haha
>>>dawdadwad
>>>fdafwa
# 服务端
(b'haha', ('127.0.0.1', 63671))
(b'dawdadwad', ('127.0.0.1', 63671))
(b'fdafwa', ('127.0.0.1', 63671))
然后我发现,我的data接收的是一个元组形式
前面的是发送的内容,后面的是客户端的ip和端口
我要内容我能理解,那我为啥还要他的ip和端口啊?
很简单,因为我得知道这个数据是谁给我发的啊,然后我好回啊
那就完成了服务端与客户端的交互了
data,client_addr = server.recvfrom(1024)
server.sendto(data.upper(),client_addr)
解决上面提出的问题,当我发空的时候,也是可以运行的,所以不用考虑空的问题
而且,因为他是数据报协议,每次发的时候其实就是把所有的信息都发过来了
这样每个数据之间就不存在联系,也就没有粘包的可能性
那既然这么方便,为什么不用UDP啊
还记得我们说过他的不安全吗?
如果数据传输中经历了网络波动,那信息就没有了
而且别人也不会再给你发一遍
再一个就是,接收信息可能不会完整(你试试把recvfrom()里面的数字变成1看看效果)
所以有这两种的不稳定性
UDP协议传输方式就不适合下载文件或者远程命令
但是查询东西用的就是UDP协议
QQ信息传输也是UDP协议
查询要的就是快,不可靠大不了我再查一遍
但是总归来说,TCP用的还是挺多的
这一part的东西其实挺少的,大部分都是概念为主
从刚开始的五层协议,进而了解到两个协议
然后通过套接字方法搭建起应用层和传输层的桥梁
接着对TCP协议模式的信息传输进行了仔细的分析
研究出一套近乎通用的模板
最后提了一下UDP协议的使用以及相对于TCP来说的优缺点
下一部分就是并发编程了,有兴趣的继续关注我吧!
*本part结束*
*写几个番外*
~~网络编程(八):UDP~~的更多相关文章
- 不为人知的网络编程(八):从数据传输层深度解密HTTP
1.引言 在文章<理论联系实际:Wireshark抓包分析TCP 3次握手.4次挥手过程>中,我们学会了用wireshark来分析TCP的“三次握手,四次挥手”,非常好用.这就是传说中的锤 ...
- 网络编程 单纯UDP通信
网络编程 单纯UDP通信 1,UDP发送端 2,UDP接收端 UDP发送端: #include <stdio.h> #include <unistd.h> #include & ...
- java:网络编程(UDP (DatagramSocket和DatagramPacket)正则表达式)
java:网络编程(UDP (DatagramSocket和DatagramPacket)正则表达式) * TCP* 特点:面向连接,点对点的通信,效率较低,但安全可靠* UDP:用户数据报协议,类似 ...
- java 网络编程-tcp/udp
--转自:http://blog.csdn.net/nyzhl/article/details/1705039 直接把代码写在这里,解释看这里吧:http://blog.csdn.net/nyzhl/ ...
- 网络编程(UDP协议-聊天程序)
网络编程中的UDP协议中聊天程序,发送端口,和接受端口. 发送端口(Send): <span style="font-size:18px;">package cn.it ...
- TCP/IP协议网络编程以及UDP和TCP之传输协议
1.什么是TCP/IP协议? 网络编程协议有很多,目前应用最广泛的是TCP/IP协议(Transmission Control Protocal/Internet Protoal 传输控制协议/英特网 ...
- Linux网络编程:UDP Socket编程范例
TCP协议提供的是一种可靠的,复杂的,面向连接的数据流(SOCK_STREAM)传输服务,它通过三段式握手过程建立连接.TCP有一种"重传确认"机制,即接收端收到数据后要发出一个肯 ...
- Java入门网络编程-使用UDP通信
程序说明: 以下代码,利用java的网络编程,使用UDP通信作为通信协议,描述了一个简易的多人聊天程序,此程序可以使用公网或者是局域网进行聊天,要求有一台服务器.程序一共分为2个包,第一个包:udp, ...
- 32.网络编程TCP/UDP服务
网络编程TCP: 服务器端口了解: port:0~65535 web服务:80 邮箱服务:556 0~1024:为服务默认的公认端口,一般我们不能用 套接字:socket socket作用 ip:po ...
- Linux 网络编程八(epoll应用--大并发处理)
//头文件 pub.h #ifndef _vsucess #define _vsucess #ifdef __cplusplus extern "C" { #endif //服务器 ...
随机推荐
- python之单元测试及unittest框架的使用
例题取用登录模块:代码如下 def login_check(username,password): ''' 登录校验的函数 :param username:账号 :param password: 密码 ...
- python 给视频添加马赛克
用法: 1. 创建空文件夹:imgs 2. 将倒数第三行中的"222056.mov"改为你的视频路径,如:"a.mov" 3. 运行以下代码 4. 稍等片刻,鼠 ...
- day10,day11—基本数据类型语法
一.整形 1. base #在16进制中的位置 num = "b" v = int(num, base=16) print(v) #11 2. bit_length() # 1 1 ...
- webpack入门进阶(3)
1.11.预处理器文件处理 1.sass文件 sass这种css预处理器是以.scss结尾,需要用node-sass和sass-loader来处理 安装loader npm i node-sass s ...
- asp .net core发布订阅kafka
Kafka是一种高吞吐量的分布式发布订阅消息系统,有如下特性: 通过O的磁盘数据结构提供消息的持久化,这种结构对于即使数以TB的消息存储也能够保持长时间的稳定性能. 高吞吐量:即使是非常普通的硬件Ka ...
- js修改函数内部的this指向(bind,call,apply)
js修改函数内部的this指向 在调用函数的时候偶尔在函数内部会使用到this,在使用this的时候发现并不是我们想要指向的对象.可以通过bind,call,apply来修改函数内部的this指向. ...
- 使用 Docker 开发 - 使用多阶段构建镜像
多阶段构建是一个新特性,需要 Docker 17.05 或更高版本的守护进程和客户端.对于那些努力优化 Dockerfiles 并使其易于阅读和维护的人来说,多阶段构建非常有用. 在多阶段构建之前 构 ...
- P2882 Face The Right Way G 题解
题目 Farmer John has arranged his N \((1 ≤ N ≤ 5,000)\) cows in a row and many of them are facing forw ...
- 点分治模板 POJ 1741
#include<cstdio> #include<cstring> #include<algorithm> using namespace std; const ...
- unity 自实现协程总结
unity本人自实现了一个协程调用. 只是moveNext()的简单协程调用和封装,这个没什么好说的, 网上例子一大堆. 但使用的过程中遇到了几个问题. 1. 自己写的moveNext() 协程不能等 ...