首页 |缤纷校园 |心理援助 |英语世界 |公务员 |考研天地 |资格考试 |电脑认证 |免费论文 |实用文档 |求职就业 |论坛 |网络课堂 |留言板
 电脑认证首页     考试专题 考试提醒 计算机等级考试 计算机认证水平考试 IT认证 论坛
 最近更新
· [学习辅导]用Java的加密机制来保护你…
· [学习辅导]如何开发、调试和测试EJB3…
· [学习辅导]Java会因为RoR的流行而过时…
· [学习辅导]谈java的导入(import)
· [学习辅导]Java程序开发中代理技术的…
· [学习辅导]如何利用JAVA实现斐波那契…
· [学习辅导]Java:Web应用下实现定时任…
· [学习辅导]Java程序把Word文档直接换…
· [备考指南]Java开发技术十年回顾与展…
· [备考指南]EasyJWeb-0.8.0版本发布
 精品课程
· [医卫类精品课程]名师主讲口腔执业医师…
· [精品课程推荐]公务员考试权威专家网…
· [医卫类精品课程]中医执业医师考试网上…
· [医卫类精品课程]临床助理医师网络辅导…
· [工程类精品课程]公路监理工程师考试网…
· [医卫类精品课程]执业药师考试网上辅导…
· [医卫类精品课程]名师执业医师考试网上…
· [工程类精品课程]物业管理师考试名师团…
· [财经类精品课程]名师主讲会计从业资格…
· [工程类精品课程]城市规划师考试名师在…
 考试动态
· [二级考试动态]北京:07年下半年计算机等…
· [二级考试动态]2008年4月全国计算机等级考…
· [二级考试动态]2007年下半年计算机等级考…
· [二级考试动态]天津:2007年下半年全国计…
· [二级考试动态]计算机技术与软件专业技术…
· [二级考试动态]2007年计算机等级考试改期…
· [二级考试动态]河北07计算机考点出故障考…
· [二级考试动态]2007年贵州省计算机补考7月…
· [二级考试动态]了解考试系列:二级C语言的…
· [二级考试动态]了解考试系列:二级VC++语…
 试题下载
· [试题下载]07年计算机等级考试二级C+…
· [试题下载]07年计算机等级考试二级C+…
· [试题下载]JavaSocket编程(二)
· [试题下载]07年计算机等级考试二级C+…
· [试题下载]07年4月计算机等级考试二级…
· [试题下载]在局域网进行IP包捕获的一…
· [试题下载]动态链接库的创建和调用
· [试题下载]计算机等级考试二级C语言模…
 学习辅导
· [学习辅导]二级C语言考试辅导教程第二…
· [学习辅导]二级C辅导教程及考点分析:…
· [学习辅导]初学者编程入门:C语言指针…
· [学习辅导]二级C宏--智者的利刃,愚者…
· [学习辅导]二级C宏--智者的利刃,愚者…
· [学习辅导]等级考试二级C专家编程读书…
· [学习辅导]等级考试二级C专家编程读书…
· [学习辅导]全国等级考试二级详细解析…
 

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

文章录入:admin    责任编辑:admin   2007-7-20 10:51:44  来源:考试大  点击数:
 

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

    er=1〉  //定义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数据包。

赛迪教育:NCRE培训课程

  • 上一个文章:

  • 下一个文章:
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    设为首页 - 加入收藏 - 联系站长 - 友情链接 - 版权申明
    Copyright©2003-2008 www.dastu.com, All Rights Reserved.

    心语心愿科技(北京)有限责任公司    版权所有

    鄂ICP备05000022号