[JavaEE] UDP协议

 

目录

                                                   

再谈端口号

一、端口号的划分

二、UDP协议

三、UDP的特点


                                                  

再谈端口号

一、端口号的划分

0-1023:知名端口号,端口号固定,其中包括HTTP,FTP,SSH等广为使用的应用层协议。

1024-65535:操作系统动态分配的端口号,客户端程序的端口号。

        1.1  ssh服务器,使用22端口

        1.2  ftp服务器,使用21端口

        1.3  telnet服务器,使用23端口

        1.4  http服务器,使用80端口

        1.5  https服务器,使用443端口

二、UDP协议

UDP协议端格式

UDP报头8个字节,没有分隔符,通过一个字段2个字节来分隔。UDP长度16比特位,2个字节,表示整个数据报(UDP首部+UDP数据)的最大长度。UDP会有一个校验和,校验和出错,就会直接丢弃。

        由于传输过程中,容易受到环境的干扰,是传输的信号发生改变,所以就需要校验和来确保文件正常。UDP使用简单有效的方案,CRC校验和(循环冗余校验和)。把UDP整个数据报都进行遍历,分别取出每一个字节,往一个 两个字节的变量上进行累加,由于数据可能很多会造成溢出的现象,不过CRC校验和并不在意溢出,会继续相加,知道相加完得到一个结果。接收方在接收之后也会进行再次相加,确保传输方和接收方两者的“CRC校验和”最终的结果一样。

 MD5算法也可以用于校验和,MD5算法 本质上是一个"字符串hash算法”,MD5的三个特性确保了做校验和的稳定性。

        一、定长:无论输入多大的数据,长度都是固定的。

        二、分散:输入的内容哪怕只有一点改变,结果都会相差很大。

        三、不可逆:计算MD5很简单,但是知道MD5的值,理论上反向破解不可能

三、UDP的特点

无连接:知道对端的IP和端口号就能直接进行传输,不需要建立连接。

不可靠:没有确认连接,没有重传机制,如果因为网络故障该段无法发送到对象,UDP协议层也不会给应用层返回任何错误信息。

面向数据报:不能够灵活的控制读写数据的次数和数量。

应用层交给UDP多长的报文,UDP原样发送,既不会拆分,也不会合并。

用UDP传输100个字节的数据:

        如果发送端调用一次sendto,发送100个字节,那么接收端也必须调用对应的一次recvfrom,接受100个字节,而不能分开接受。

UDP使用注意事项

UDP传输最大长度是64K(包含UDP首部),如果我们传输的数据超过64K,接需要在应用层手动的分包,分多次发送,在接收端手动拼接。

基于UDP的应用层协议

NFS: ⽹络⽂件系统

TFTP: 简单⽂件传输协议

DHCP: 动态主机配置协议

BOOTP: 启动协议(⽤于⽆盘设备启动)

DNS: 域名解析协议

=========================================================================

最后如果感觉对你有帮助的话,不如给博主来个三连,博主会继续加油的ヾ(◍°∇°◍)ノ゙

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值