TCP&UDP伪首部详解
来源:互联网 发布:金谷网络视频会议 编辑:程序博客网 时间:2024/06/14 22:44
最近在读Stevens 的tcp/ip详解,其中介绍到了UDP和TCP伪首部但是介绍的不够详细,只说是为了UDP和TCP校验和存在的 ,同时给出了一个伪首部的图,是直接加在UDP首部前面的,给我的困惑貌似是真实存在的,其实这个图应该用虚线表示,下面就我的理解,介绍一下伪首部:
1. 伪首部并非TCP&UDP数据报中实际的有效成分。伪首部是一个虚拟的数据结构,其中的信息是从数据报所在IP分组头的分组头中提取的,既不向下传送也不向上递交,而仅仅是为计算校验和。
这样的校验和,既校验了TCP&UDP用户数据的源端口号和目的端口号以及TCP&UDP用户数据报的数据部分,又检验了IP数据报的源IP地址和目的地址。伪报头保证TCP&UDP数据单元到达正确的目的地址。因此,伪报头中包含IP地址并且作为计算校验和需要考虑的一部分。最终目的端根据伪报头和数据单元计算校验和以验证通信数据在传输过程中没有改变而且到达了正确的目的地址。
2.伪首部,更确切的说是校验和包含的—个96位的伪首标,是个理论上的值,只是理论上它位于TCP&UDP首标的前面。这个伪首标包含了源地址、目的地址、协议和TCP&UDP长度等字段,这使得TCP&UDP能够防止出现路由选择错误的数据段。这些信息由网际协议(IP)承载,通过TCP&UDP网络接口,在IP上运行的TCP&UDP调用参数或者结果中传递。
附:校验和计算方法,以ip首部为例
为了计算一份数据报的IP检验和,首先把检验和字段置为0。然后,对首部中每个16bit进行二进制反码求和(整个首部看成是由一串16bit的字组成),结果存在检验和字段中。当收到一份IP数据报后,同样对首部中每个16bit进行二进制反码的求和。由于接收方在计算过程中包含了发送方存在首部中的检验和,因此,如果首部在传输过程中没有发生任何差错,那么接收方计算的结果应该为全1。如果结果不是全1(即检验和错误),那么IP就丢弃收到的数据报。但是不生成差错报文,由上层去发现丢失的数据报并进行重传。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wufen_1981/archive/2007/12/28/1998518.aspx
- TCP&UDP伪首部详解
- TCP&UDP伪首部详解
- 【转载】TCP&UDP伪首部详解
- TCP/UDP 伪首部
- TCP,UDP伪首部描述
- IP、TCP、UDP首部详解
- IP、TCP、UDP首部详解
- IP、TCP、UDP首部详解
- UDP和TCP中的伪首部
- UDP伪首部
- tcp/udp校验和以及伪首部介绍
- IP首部、TCP首部、UDP首部
- UDP伪首部的作用
- 计算机网络学习--tcp伪首部
- tcp/ip primer plus 第九章用户数据报协议(UDP)& 伪首部
- TCP IP首部详解
- 《TCP/IP详解,卷2:实现》读书笔记-UDP和TCP的首部
- 以太网帧,IP,TCP,UDP首部结构
- 【模拟】【RQNOJ】验证数独
- REST 相关介绍和学习资料
- 新手学习GTK入门教程 第二讲
- Quick_Sort
- PHP新的垃圾回收机制:Zend GC详解
- TCP&UDP伪首部详解
- 《PHP Cookbook》学习笔记(七)
- QTP项目实战课程测试脚本下载
- 3D引擎开发,慎用逆矩阵
- [64位操作系统]未在本地计算机上注册“Microsoft.Jet.OLEDB.4.0” 提供程序
- 怀才不遇。
- #ifndef#define#endif的用法
- Linux下软件安装详解(图)
- Understanding PHP Opcode (Forward)