当前位置:  技术问答>linux和unix

请教使用libpcap抓包的几个问题

    来源: 互联网  发布时间:2015-05-16

    本文导语:  目的是抓通过网卡+ADSL MODEM上网的包, 能知道包的源/目的地址与收发的字节大小.  参考了几个例子后, 我写了以下代码.  pcap_lookupdev(...);  pcap_lookupnet(...);  pcap_open_live(...);//混杂模式  pcap_loop(...);  在回调函数中, ...

目的是抓通过网卡+ADSL MODEM上网的包, 能知道包的源/目的地址与收发的字节大小. 
参考了几个例子后, 我写了以下代码. 
pcap_lookupdev(...); 
pcap_lookupnet(...); 
pcap_open_live(...);//混杂模式 
pcap_loop(...); 
在回调函数中, 我是这样写的: 
u_int16_t handle_ethernet(u_char *args, const struct pcap_pkthdr *pkthdr, const u_char *packet) 

struct ether_header *eptr; 
eptr=(struct ether_header*)packet;//转成以太网包头后分析其协议类型 
if(ntohs(eptr->ether_type)==ETHERTYPE_IP) 

printf("ipn"); 

else if(ntohs(eptr->ether_type)==ETHERTYPE_ARP) 

printf("arpn"); 

elseif(ntohs(eptr->ether_type)==ETHERTYPE_REVARP) 

printf("revarpn"); 

else 
printf("unknownn"); 
... 

1. 
结果是当我ping 192.168.1.1(我的ADSL MODEM)时, 包是IP型的; 当我ping www.google.com时, 包都属于unknown类型. 我的理解是这个struct ether_header结构体类型只定义了IP,ARP,REVARP, 而与互联网通讯的协议是TCP和UDP, 所以是unknown, 不知对不对? 

2. 
为此, 我修改了回调函数, 把packet转成struct ip结构体类型, 但是我看过此类型的定义都找不到从哪个成员可看出此包的协议类型(例如TCP,UDP), 请问是哪一个成员? 这个成员的值的宏定义在哪个文件? 

3. 
因为struct ip的最后两个成员是struct in_addr ip_src和ip_dst, 我就根据别的例子这样写inet_ntoa(ip->ip_src)和inet_ntoa(ip->ip_dst)来取得源IP和目的IP, 结果是当我ping 192.168.1.1(我的ADSL MODEM)时, 显示是正确的; 当我ping www.google.com时, 显示却是错误的. 是什么原因呢? 正确的做法是怎样? 

我查阅了这里所有与libpcap有关的文章, 都没有得到答案. 我知道用SOCKET也可实现libpcap的所有功能, 但我想先用libpcap实现了, 再用SOCKET做. 谢谢你的答复. 

|
你ping www.google.com是不是先抓到了域名解析的包? try ping IP of google directly

|
PING使用ICMP协议,封在IP包内,数值在IP包类协议字节部分

|
struct ether_header结构体类型只定义了IP,ARP,REVARP, 而与互联网通讯的协议是TCP和UDP, 所以是unknown, 不知对不对? 

错!!!ICMP IGMP TCP UDP都是封装成IP包!

    
 
 

您可能感兴趣的文章:

  • 请教大家linux下建立视频的服务器几个问题
  • Qt初学者请教大家几个问题!
  • 请教 Linux下安装ORACLE的几个问题
  • 请教几个问题?
  • 各位高手大家好,我是初学LINUX想请教几个问题
  • 请教 几个问题!!!!谢谢!!!
  • 初学Linux内核编译,几个问题请教一下
  • 请教一下unix下的几个问题
  • 请教VI的几个问题,谢谢
  • 关于硬盘安装radhat7.3的几个问题?请教大虾
  • 几个问题请教高手,没把握不要乱说哟!
  • 多系统引导程序的几个问题,请教???
  • 想请教shell编程几个问题
  • 初装linux,好几个问题要请教!
  • 请教几个问题
  • 请教一下linux系统中程序运行方式的几个问题
  • 我想学JAVA,有几个问题想请教大家。
  • 请教关于syslogd和printk的几个问题
  • 我是初学者,有几个问题,想请教各位高手,望不吝赐教
  • 这里有青岛的java程序员吗??有几个问题请教一下!(大送分)
  • 请教菜鸟问题 libpcap达人路过看看
  • libpcap丢包问题请教
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请教,请教,这个问题是为什么????
  • 请教本地硬盘安装问题请教本地硬盘安装问题
  • ■请教■请教redhat最基本的问题!
  • 请教一个 shell 问题,我用下面这个 shell 语句总是失败,请教
  • 高分请教,各位大侠,请教一个问题,理论高手请进??谢谢
  • 请教Linux下pgadmin3-1.0.2的编译和安装!!高分请教!
  • 各位大虾,请教装了REDHAT9操作系统后,启动时无法引导到LINUX,请教该如何解决啊
  • 请教,请教,,,一定要看!!一定要看!!
  • 请教高手,小弟打印width=1500,height=600(A3纸)的Applet,在预览中是该区域是黑的,打印出来也是黑的,请教高手解决一下
  • :请教高手,小弟打印width=1500,height=600(A3纸)的Applet,在预览中是该区域是黑的,打印出来也是黑的,请教高手解决一下
  • 请教象我这样的硬盘应如何安装Linux,我昨天试装了,但有问题。(老问题了,也看了前面的帖子,但还是来请教,请多指教)
  • 请教这种循环的执行过程
  • 请教两个redhat9问题
  • 请教如何在指定目录下查找包含指定文字的文件
  • 请教局域网中如何通过ip地址得到主机名
  • 博客 iis7站长之家
  • 请教linux 下的adsl拨号问题.
  • 请教,如何用虚拟订机安装liux
  • 【请教】LINUX 下SNMP的MIB开发
  • 请教一个opengl的问题


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3