执着成就未来 技术成就梦想
文字横幅以及760*60黄金广告位置招租,欢迎恰谈! 广告业务联系QQ:8019399 声明:在本站所投放广告内容均与本站立场无关!

您现在的位置: 中国安全在线 >> 攻防技术 >> 菜鸟学习 >> 文章正文 用户登录 新用户注册
专 题 栏 目
最 新 热 门
最 新 推 荐
相 关 文 章
局域网中解决盗用MAC地址上网问题
合理设置ARP维护局域网秩序
教你如何防范局域网的病毒传播
无线局域网嗅探技术与防范策略
局域网伪造源地址DDoS攻击解决方法
攻防:局域网监听的原理、实现与防
利用DNS欺骗在局域网中挂马
在局域网中进行IP包捕获的一种方法
作者:佚名 来源:安全在线 更新时间:2007-1-15 【字体:
<%=(int(rnd()*1)+1)%>您当前的位置:中国安全在线cnsafer.com 请进入[技术论坛]发表评论

阅读提示:

在局域网进行IP包捕获的一种方法

首先是几个结构的定义(网上搜索或者查阅相关文档):

//定义IP地址结构

struct IPADDRESS

{

unsigned short ip_a,

ip_b,

ip_c,

ip_d;

};

//定义IP数据包头的结构

struct IP_HEADER

{

unsigned short ip_version, /*IP的版本号 */

ip_hdr_len, /*IP包头的长度*/

ip_tos, /*IP包的服务类型*/

ip_total_len, /*IP包的总长度*/

ip_id, /*IP包的分段标识*/

ip_flags, /*IP包的分段标志*/

ip_frag_offset, /*IP包的分段偏移*/

ip_ttl, /*IP包的生存时间*/

ip_proto, /*IP包的高层协议*/

ip_hdr_chksum; /*IP包的校验和*/

struct IPADDRESS ip_src_addr, /*IP包的源IP地址*/

ip_dest_addr; /*IP包的目的IP地址*/

}ipheader;

//IP包的链表结构

struct stru_ip_link

{

char rcv_ip_buf[MAX_IP_SIZE];

struct stru_ip_link *next;

};

然后是协议的定义(包含相应的头文件#include #include):

DWORD dwIoControlCode=SIO_RCVALL, /*接收所有的IP包*/

dwProtocol=IPPROTO_IP; /*协议类型为IP*/

然后是相应的捕获处理:

1.加载 Winsock

2.创建一个接收原始IP包的socket连接

3.绑定到一个接口

4.进行WSAIoctl设置,接收所有的IP数据

参考代码:

if (WSAIoctl(s, dwIoControlCode, &optval, sizeof(optval),

NULL, 0, &dwBytesRet, NULL, NULL) == SOCKET_ERROR)

...

5.接着设定一个线程进行捕获:

(1)创建一个接收IP包的链表头

(2)设置一个标识,为真,则不断进行IP包的捕获

(3)建立一个新的结点,将捕获的数据包加入到该结点

(4)如果链表的长度达到指定的长度,创建一个线程对该链表的IP包进行解析;再设置一个在IP数据包链表不足给定的长度,而又中止IP捕获时,对链表的处理

(5)为下一个IP包链表创建一个链表头

6.建立一个进行IP包解析并显示的线程,进行解析IP数据包,然后显示IP数据包。

您对本文章有什么意见或着疑问吗?请到论坛讨论您的关注和建议是我们前行的参考和动力

文章录入:ls1238    责任编辑:ls1238 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    | 设为首页 | 加入收藏 | 联系方式 | 友 情链接 | 关于我们 | 网站留言 |
    Copyright ?2003-2008 www.cnsafer.com All Rights Reserved.
    如有意见请与我们联系 Email:admin#mail.cnsafer.com 联系QQ:8589101
    中国安全在线友情提示:建议使用IE6.0或以上版本, 分辩率1024*768进行浏览
    敢想 敢做 挑战自我 努力做最好 打造最优秀的新手成长 第一起跑线
    中网科技有限公司 技术支持 鄂ICP备05006475号