计算机网络-传输层(UDP协议报文格式,伪首部,UDP校验过程)

1. UDP协议

UDP只在IP数据报服务之上增加了很少功能,即复用分用和差错检测功能。

UDP的主要特点:

  1. UDP是无连接的,减少开销和发送数据之前的时延。

  2. UDP使用最大努力交付,即不保证可靠交付。

  3. UDP是面向报文的,适合一次性传输少量数据的网终应用。

    应用层给UDP多长的报文,UDP就照样发送,即一次发一个完整报文。

    UDP报文太长,会导致数据报在网络层分片,导致效率低,
    UDP报文太低,导致网络层的IP报头比有效载荷长很多,导致效率下降。

    所以应用层传输的数据报长度需要适中。

  4. UDP没有拥塞控制,适合很多实时应用。(视频会议)

  5. UDP首部开销比较小8B,TCP首部固定字段20B(不包括选项字段和填充字段)

UDP报文格式

在这里插入图片描述
16位UDP长度:代表的是UDP报文的整个长度
16位UDP检验和:检验整个UDP数据报是否出错。出错就丢弃报文。

UDP报文分用时,找不到对应的目的端口号,就丢弃报文。
并给发送方发送ICMP端口不可达差错报告报文.

UDP校验过程

在这里插入图片描述

伪首部:

  1. 在计算校验和的时候才出现,不向上传递或向下传递
  2. 伪首部的第三个字段为全0
  3. 第四个字段17代表,封装UDP报文的IP数据报首部协议字段是17。
  4. UDP长度:UDP首部8B+数据部分长度(不包括伪首部)。

伪首部校验过程:
在这里插入图片描述
上图中每一行都是4字节。有时UDP报文数据部分不一定是4字节的整数倍,需要在后面填充0到4字节整数倍。

UDP校验在发送方:

  1. 填充伪首部
  2. 校验和字段全部填写为0(初始化校验和)
  3. 数据部分填充到4字节的倍数。
  4. 伪首部+首部+数据部分采用二进制反码求和。
  5. 将求和结果求反码填充到校验和字段
  6. 去掉伪首部,发送数据

UDP校验在接收方:

  1. 填上伪首部
  2. 伪首部+首部+数据部分采用二进制反码求和。(此时校验和字段不是0)
  3. 结果二进制序列全为1则无差错,否则丢弃数据报或交给应用层附上出差错的警告。差错控制由应用层负责。
  • 1
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在计算UDP校验和时,需要包含首部,其主要原因是为了提高校验和的准确性和可靠性。 UDP协议中的校验和是通过对UDP数据报的每一位进行加法运算得到的,然后将结果取反作为校验和。如果不包含首部,那么校验和仅仅只能检测到UDP数据报本身的错误,而无法检测到IP首部的错误,这就会导致误判。因此,在计算UDP校验和时,需要将IP首部中的源IP地址、目的IP地址、协议号和UDP数据报长度等信息加入到首部中,并将首部UDP数据报一起进行校验和计算,这样可以有效地提高校验和的准确性和可靠性,避免误判的发生。 ### 回答2: UDP协议在计算“校验和”时要包含首部,主要是为了增加校验的准确性和安全性。 首部UDP协议计算校验和时加入到数据中的一个虚拟的首部,由发送方构造,接收方校验首部包含源IP地址、目的IP地址、0x00、IP协议(UDP协议协议号),它们与真实的IP首部中的相应字段相同。在计算校验和时,源IP地址、目的IP地址、IP协议字段都参与了运算,从而保证了校验和的准确性。 为什么要包含首部呢?首先,UDP协议是无连接的传输层协议,没有像TCP协议那样建立连接时互相验证的过程,因此需要通过校验和来判断数据是否完整和正确。其次,通过包含首部的方式,可以使得校验和算法考虑到了IP层的信息,从而提高了校验的准确性。而且,首部中的源IP地址和目的IP地址可以确保数据包没有被篡改或造,增加了数据的安全性。 总结起来,UDP协议在计算校验和时包含首部是为了保证数据传输的完整性和准确性,同时增加了数据的安全性。通过包含源IP地址、目的IP地址、0x00、IP协议等信息,提高了校验和的准确性和可靠性。 ### 回答3: UDP协议在计算“校验和”时要包含首部,主要是为了提高数据包的可靠性和减少出错的可能性。 首先,首部是为了确保数据报文在传输过程中的完整性和正确性。UDP协议通过在数据包中添加首部,将源IP地址、目标IP地址、协议类型和UDP长度等信息包含在内,然后对整个数据包进行校验和计算。这样,一旦数据包在传输过程中发生改变或出现错误,接收端可以通过校验和的计算结果进行验证,从而及时检测出错误并进行处理。 其次,首部的使用可以提高UDP协议的可靠性和减少出错的可能性。在传输过程中,由于网络环境的不稳定性和传输介质的干扰等原因,数据包很容易出现传输错误、丢失或乱序等情况。通过使用首部,接收端可以检测到因为数据包被篡改、丢失或重复发送等问题导致的校验和错误,从而及时进行处理或请求重传。 最后,包含首部还可以帮助接收端正确地识别和分辨不同的数据包。当多个数据包同时到达接收端时,接收端可以通过比较首部中的源IP地址和目标IP地址等信息,将数据包正确地归类和处理。 综上所述,UDP协议在计算“校验和”时包含首部的目的是为了增加数据包的可靠性,减少传输错误的可能性,并帮助接收端正确地识别和处理数据包。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NUC_Dodamce

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值