网络程序设计-09-原始套接字-网络嗅探器v1.0.0.pptVIP

网络程序设计-09-原始套接字-网络嗅探器v1.0.0.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
网络程序设计-09-原始套接字-网络嗅探器v1.0.0

* Background provided by m62 Visualcommunications, visit for more information * 《信息安全管理》徐国爱—北邮出版 * 《信息安全管理》徐国爱—北邮出版 * 《信息安全管理》徐国爱—北邮出版 * 《信息安全管理》徐国爱—北邮出版 * 《信息安全管理》徐国爱—北邮出版 * 《信息安全管理》徐国爱—北邮出版 * 《信息安全管理》徐国爱—北邮出版 * Background provided by m62 Visualcommunications, visit for more information 原始套接字 ——网络嗅探器 《网络程序设计》 * 原始套接字-引入 前续课程中我们了解到,使用Socket可以方便的进行网络通信,通信内容由Socket封装为TCP/UDP数据报在网络上传输,开发者不用关心TCP/UDP数据报文是如何封装的。 但是,有时我们需要对底层网络协议进行处理,如发送自定义的IP包、接收/解析网络上的数据包等。 这时就需要使用原始套接字技术。 * 原始套接字 原始套接字概述 协议数据头部格式定义 网络嗅探器开发实例 小结 动手实践 * 原始套接字 原始套接字概述 协议数据头部格式定义 网络嗅探器开发实例 小结 动手实践 * 1. 原始套接字概述 1.1. 什么是原始套接字 原始套接字(Raw Socket)是一种套接字类型,是使开发者能够直接对底层网络协议数据报(如IP报文)进行处理的套接字。 Raw英文含义: adj.生的,未加工的;n.半成品,原料。 * 1. 原始套接字概述 1.2. 原始套接字的适用场景 (1)发送自己封装的网络报文 可以是预定义的协议,如ICMP、TCP、UDP等; 也可以是自定义的协议。 (2)接收/解析原始网络报文 常见的网络嗅探器(sniffer)就是抓取和解析原始的网络报文实现的。 * 1. 原始套接字概述 1.3. 如何创建原始套接字 示例: SOCKET rawSocket = socket(AF_INET, SOCK_RAW, IPPROTO_IP); * 1. 原始套接字概述 1.4. 需要注意的问题 (1)操作系统对原始套接字的使用有一定限制 (2)使用原始套接字需要深入理解TCP/IP协议格式 * 原始套接字 原始套接字概述 协议数据头部格式定义 网络嗅探器开发实例 小结 动手实践 * 2. 协议数据头部格式定义 2.1. IPv4头格式 typedef struct _IPHeader // 20字节的IP头 { UCHAR iphVerLen; // 版本号和头长度(各占4位) UCHAR ipTOS; // 服务类型 USHORT ipLength; // 封包总长度,即整个IP报的长度 USHORT ipID; // 封包标识,惟一标识发送的每一个数据报 USHORT ipFlags; // 标志 UCHAR ipTTL; // 生存时间,就是TTL UCHAR ipProtocol; // 协议,可能是TCP、UDP、ICMP等 USHORT ipChecksum; // 校验和 ULONG ipSource; // 源IP地址 ULONG ipDestination; // 目标IP地址 } IPHeader, *PIPHeader; * 2. 协议数据头部格式定义 2.2. TCP头格式 typedef struct _TCPHeader // 20字节的TCP头 { USHORT sourcePort; // 16位源端口号 USHORT destinationPort; // 16位目的端口号 ULONG sequenceNumber; // 32位序列号 ULONG acknowledgeNumber; // 32位确认号 UCHAR dataoffset; // 高4位表示数据偏移 UCHAR flags; // 6位标志位 USHORT windows; // 16位窗口大小 USHORT checksum; // 16位校验和 USHORT urgentPointe

文档评论(0)

yongbuwang + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档