第13章节原始套接字.ppt

  1. 1、本文档共35页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第13章节原始套接字

第13章 原始套接字 通常情况下程序设计人员接触的网络知识限于如下两类: 流式套接字(SOCK_STREAM),它是一种面向连接的套接字,对应于TCP应用程序。 数据报套接字(SOCK_DGRAM),它是一种无连接的套接字,对应于的UDP应用程序。 除了以上两种基本的套接字外还有一类原始套接字,它是一种对原始网络报文进行处理的套接字。 13.1 概述 前面几章介绍了基础的套接字知识,流式套接字(SOCK_STREAM)和数据报套接字(SOCK_DGRAM)涵盖了一般应用层次的TCP/IP应用。 13.2 原始套接字的创建 原始套接字的创建使用与通用的套接字创建的方法是一致的,只是在套接字类型的选项上使用的是另一个SOCK_RAW。在使用socket函数进行函数创建完毕的时候,还要进行套接字数据中格式类型的指定,设置从套接字中可以接收到的网络数据格式。 13.2.1 SOCK_RAW选项 创建原始套接字使用函数socket,第二个参数设置为SOCK_RAW,函数socket()可以创建一个原始套接字。下面的代码,创建一个AF_INET协议族中的原始套接字,协议类型为protocol。 int rawsock = socket(AF_INET, SOCK_RAW, protocol); 13.2.2 IP_HDRINCL套接字选项 使用套接字选项IP_HDRINCL设置套接字,在之后进行的接收和发送的时候,接收到的数据包含IP数据的,包含IP的头部。用户之后需要对IP层相关的数据段进行处理,例如IP头部数据的设置和分析,校验和的计算等。设置方法如下: int set = 1; if(setsockopt(rawsock, IPPROTO_IP, IP_HDRINCL, set, sizeof(set))0){ } 13.2.3 不需要bind()函数 原始套接字不需要使用bind()函数,因为进行发送和接收数据的时候可以指定要发送和接收的目的地址的IP。例如使用函数sendto()和函数recvfrom()来发送和接收数据,sendto()和recvfrom()函数分别需要指定IP地址。 sendto (rawsock, data, datasize, 0, (struct sockaddr *) to, sizeof (to)); recvfrom(rawsock, data,size , 0,(struct sockaddr)from, len) ; 当系统对socket进行了绑定的时候,发送和接收的函数可以使用send()和recv()及read()和write()等不需要指定目的地址的函数。 13.3 原始套接字发送报文 原始套接字发送报文有如下的原则: 通常情况下可以使用sendto()函数并指定发送目的地址发送数据,当已经bind()了目标地址的时候可以使用write()或者send()发送数据。 如果使用setsockopt()设置了选项IP_RINCL,则发送的数据缓冲区指向IP头部第一个字节的头部,用户发送的数据包含IP头部之后的所有数据,需要用户自己填写IP头部和计算校验和及所包含数据的处理和计算。 如果没有设置IP_RINCL,则发送缓冲区指向IP头部后面数据区域的第一个字节,不需要用户填写IP头部,IP头部的填写工作有内核进行,内核还进行校验和的计算。 13.4 原始套接字接收报文 接收报文还有自己的一些特点,主要有如下几个: 对于ICMP的协议,绝大部分数据可以通过原始套接字获得,例如回显请求、响应,时间戳请求等。 接收的UDP和TCP协议的数据不会传给任何原始套接字接口,这些协议的数据需要通过数据链路层获得。 如果IP以分片形式到达,则所有分片都已经接收到并重组后才传给原始套接字。 内核不能识别的协议、格式等传给原始套接字,因此,可以使用原始套接字定义用户自己的协议格式。 13.5 原始套接字报文处理时的结构 本节介绍进行报文处理时常用的数据结构,包含IP头部、ICMP头部、UDP头部、TCP头部。使用这些数据格式对原始套接字进行处理,可以从底层获取高层的网络数据。 13.5.1 IP头部的结构 13.5.2 ICMP头部结构 ICMP的头部结构比较复杂,主要包含消息类型icmp_type,消息代码icmp_code、校验和icmp_cksum等,不同的ICMP类型其他部分有不同的实现。 1.ICMP的头部结构 2.不同类型的ICMP请求 13.5.3 UDP头部结构 13.5.4 TCP头部结构 TCP的头部结构主要包含发送端的源端口、接收端的目的端口、数据的序列号、上一个数据的确认号、滑动窗口大小、数据的校验和、紧急数据的偏移指针以及一些控制位等信息。 13.5.4 T

文档评论(0)

wuyoujun92 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档