通行证: 用户 密码 域名空间  下载中心 社区论坛 信息公告 my小屋
联系我们
设为首页
加入收藏

 

qq,asp,php,jsp,xml,sql,.net,编程 程序 网页图象 建站经验 私服
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿
论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图
专题 | 应用软件 | 聊天通讯 | q q 专栏 | 建站经验 | 在线工具 | 站长club | 注 册 表 | 旧版
社会 | 游戏娱乐 | 设计欣赏 | 疑难解答 | 社区论坛 | 网络赚钱 | 网站地图 | 广告服务 | 服务
当前位置:首页>>编程开发>>vc编程>>正文 新版上线![旧版]
注:打开慢时请稍等
vc++编程实现网络嗅探器

http://www.iyit.net  日期:2006-5-3 21:12:01  来源:yesky  点击:
参加讨论

  引言

  从事网络安全的技术人员和相当一部分准黑客(指那些使用现成的黑客软件进行攻击而不是根据需要去自己编写代码的人)都一定不会对网络嗅探器(sniffer)感到陌生,网络嗅探器无论是在网络安全还是在黑客攻击方面均扮演了很重要的角色。通过使用网络嗅探器可以把网卡设置于混杂模式,并可实现对网络上传输的数据包的捕获与分析。此分析结果可供网络安全分析之用,但如为黑客所利用也可以为其发动进一步的攻击提供有价值的信息。可见,嗅探器实际是一把双刃剑。 虽然网络嗅探器技术被黑客利用后会对网络安全构成一定的威胁,但嗅探器本身的危害并不是很大,主要是用来为其他黑客软件提供网络情报,真正的攻击主要是由其他黑软来完成的。而在网络安全方面,网络嗅探手段可以有效地探测在网络上传输的数据包信息,通过对这些信息的分析利用是有助于网络安全维护的。权衡利弊,有必要对网络嗅探器的实现原理进行介绍。

  嗅探器设计原理

  嗅探器作为一种网络通讯程序,也是通过对网卡的编程来实现网络通讯的,对网卡的编程也是使用通常的套接字(socket)方式来进行。但是,通常的套接字程序只能响应与自己硬件地址相匹配的或是以广播形式发出的数据帧,对于其他形式的数据帧比如已到达网络接口但却不是发给此地址的数据帧,网络接口在验证投递地址并非自身地址之后将不引起响应,也就是说应用程序无法收取到达的数据包。而网络嗅探器的目的恰恰在于从网卡接收所有经过它的数据包,这些数据包即可以是发给它的也可以是发往别处的。显然,要达到此目的就不能再让网卡按通常的正常模式工作,而必须将其设置为混杂模式。

  具体到编程实现上,这种对网卡混杂模式的设置是通过原始套接字(raw socket)来实现的,这也有别于通常经常使用的数据流套接字和数据报套接字。在创建了原始套接字后,需要通过setsockopt()函数来设置ip头操作选项,然后再通过bind()函数将原始套接字绑定到本地网卡。为了让原始套接字能接受所有的数据,还需要通过ioctlsocket()来进行设置,而且还可以指定是否亲自处理ip头。至此,实际就可以开始对网络数据包进行嗅探了,对数据包的获取仍象流式套接字或数据报套接字那样通过recv()函数来完成。但是与其他两种套接字不同的是,原始套接字此时捕获到的数据包并不仅仅是单纯的数据信息,而是包含有 ip头、 tcp头等信息头的最原始的数据信息,这些信息保留了它在网络传输时的原貌。通过对这些在低层传输的原始信息的分析可以得到有关网络的一些信息。由于这些数据经过了网络层和传输层的打包,因此需要根据其附加的帧头对数据包进行分析。下面先给出结构.数据包的总体结构:

数据包
ip头tcp头(或其他信息头)数据

  数据在从应用层到达传输层时,将添加tcp数据段头,或是udp数据段头。其中udp数据段头比较简单,由一个8字节的头和数据部分组成,具体格式如下:

16位16位
源端口目的端口
udp长度udp校验和

  而tcp数据头则比较复杂,以20个固定字节开始,在固定头后面还可以有一些长度不固定的可选项,下面给出tcp数据段头的格式组成:

16位 16位
源端口目的端口
顺序号
确认号
tcp头长(保留)7位urgack pshrstsynfin 窗口大小
校验和 紧急指针
可选项(0或更多的32位字)
数据(可选项)

  对于此tcp数据段头的分析在编程实现中可通过数据结构_tcp来定义:

typedef struct _tcp{ word srcport; // 源端口
word dstport; // 目的端口
dword seqnum; // 顺序号
dword acknum; // 确认号
byte dataoff; // tcp头长
byte flags; // 标志(urg、ack等)
word window; // 窗口大小
word chksum; // 校验和
word urgptr; // 紧急指针
} tcp;
typedef tcp *lptcp;
typedef tcp unaligned * ulptcp;

  在网络层,还要给tcp数据包添加一个ip数据段头以组成ip数据报。ip数据头以大端点机次序传送,从左到右,版本字段的高位字节先传输(sparc是大端点机;pentium是小端点机)。如果是小端点机,就要在发送和接收时先行转换然后才能进行传输。ip数据段头格式如下:

16位16位
版本 ihl 服务类型总长
标识 标志分段偏移
生命期协议 头校验和
源地址
目的地址
选项(0或更多)

  同样,在实际编程中也需要通过一个数据结构来表示此ip数据段头,下面给出此数据结构的定义:

typedef struct _ip{
union{ byte version; // 版本
byte hdrlen; // ihl
};
byte servicetype; // 服务类型
word totallen; // 总长
word id; // 标识
union{ word flags; // 标志
word fragoff; // 分段偏移
};
byte timetolive; // 生命期
byte protocol; // 协议
word hdrchksum; // 头校验和
dword srcaddr; // 源地址
dword dstaddr; // 目的地址
byte options; // 选项
} ip;
typedef ip * lpip;
typedef ip unaligned * ulpip;

  在明确了以上几个数据段头的组成结构后,就可以对捕获到的数据包进行分析了。

共2页。 1 2 8 :

编辑:黑鹰 [发送给好友] [打印本页] [关闭窗口] [返回顶部]
上一篇:vc编程轻松获取局域网连接通知
下一篇:用vc++6.0编写proxy服务器
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
vc++实现对远程计算机屏幕的监视 vc下揭开“特洛伊木马”的隐藏面纱 多线程技术在vc++串口通信程序中的应用
用vc++制作一个简单的局域网消息发送工 用vc++6.0的sockets api实现一个聊天室 用vc++实现上网拨号功能
vc++ smtp协议电子邮件传送剖析 vc++实现gps全球定位系统定位数据的提取 用vc 6.0实现串行通信的三种方法
用vc++6.0编写proxy服务器 vc编程轻松获取局域网连接通知 用vc++实现版本在线升级
vc下用win32 api实现串行通信 vc++多串口控制解决方案api版 vc编程用upd协议实现广播通信
基于vc的串行通信技术应用实例 vc下使用icmp实现路由跟踪 vc下用mfc类实现网络编程
用vc++6.0实现snmp协议的方法 vc6.0编写c/s消息传送程序 实例解析ipv6下的vc网络编程
用vc++实现企业网络数据共享 vc++下用mscomm控件实现串口通讯 vc6中用dom遍历网页中的元素
最新更新 热点排行 推荐新闻
vc++实现对远程计算机屏幕的监视
vc下揭开“特洛伊木马”的隐藏面纱
多线程技术在vc++串口通信程序中的应用
用vc++制作一个简单的局域网消息发送工
用vc++6.0的sockets api实现一个聊天室
去除dw mx 2004表格宽度辅助
驯服不听话的网页表格
dw mx 2004代码编辑新功能
细品dw mx 2004内建fw技术
用 javascript 写的一个映射表类
dreamweaver里使用层的一些建议
表格边框魔鬼教程
用dreamweaver进行网页优化
用dreamweaver制作拖拽效果
寻找dreamweaver鲜为人知的小秘诀
vc++实现对远程计算机屏幕的监视
vc++实现gps全球定位系统定位数据的提
vc下揭开“特洛伊木马”的隐藏面纱
多线程技术在vc++串口通信程序中的应用
用vc++制作一个简单的局域网消息发送工
qq珊瑚虫外挂4.0版本发布!
多个广告位招商!
摄影后期系列一:1分钟为数码相片去红眼
教您显示器亮度对比度的调节
qq挂机说明
asp进度条
photoshop通道抠图:给秀发飞扬的mm照
新版上线,今日正式开通!!!
更多精彩图文广告等着您!
免费在qq上看在线电影电视听音乐
第二十章 开发delphi对象式数据管理功
sql简明教程(1)
vbscript和javascript互相调用 
jsp教程(四)-jsp actions的使用
操作系统被入侵后的修复过程
五一别忘电脑防毒 养成良好上网习惯
google对ie浏览器将捆绑搜索功能表担忧
新版上线,今日正式开通!!!
用photoshop创意图形“岁月”
摄影后期系列一:1分钟为数码相片去红眼

 友情链接
设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
copyrights © 2004-2006 iyit.net all rights reserved.
网站合作、广告联系qq:147007642、466949678
易特网络技术 点击这里给我发消息