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

Linux网络抓包的程序 [使用recvfrom之后无限阻塞]

    来源: 互联网  发布时间:2016-06-07

    本文导语:  操作系统: ubuntu 2.6.24 g++ 网络没有问题 程序原理是 : 1,先创建一个RAW的socket, 2,再把网卡设为混杂模式。 3,使用recvfrom开始抓包。 症状描述: recvfrom一直阻塞,不返回任何值: 下面是代码: #include  // for ...

操作系统:
ubuntu 2.6.24
g++
网络没有问题

程序原理是 :
1,先创建一个RAW的socket,
2,再把网卡设为混杂模式。
3,使用recvfrom开始抓包。

症状描述:
recvfrom一直阻塞,不返回任何值:

下面是代码:
#include  // for AF_INET SOCK_RAW
#include  // for socket
#include  // for sockaddr_in
#include  // for strerror
#include  // for errno
#include  // for ioctl
#include  // for ifreq
#include 
#include 
#include 

#define DIE(x) printf(x);printf("Error Infor = [ %s ] ",strerror(errno)); 
exit(1);
#define BUFF_SIZE 2048
#define PORT_NUMBER 12345

struct ifreq ifr;

int main(int argc,char *argv[])
{
int sock;
sockaddr_in addr_in;

        // 网上也有人用 sock = socket(AF_INET,SOCK_PACKET,htonl(EH_P_IP)),我试了下,结果和 这个一样
if (-1 == (sock = socket(AF_INET, SOCK_RAW,htonl(ETH_P_ALL))))
{
DIE("Create socket failed.n")
}

       // 用ifconfig试了下,我的网卡是eth1
strcpy(ifr.ifr_name, "eth1");
if (ioctl(sock, SIOCGIFFLAGS, &ifr) == -1)
{
DIE("ioctl failed.n");
}

ifr.ifr_flags |= IFF_PROMISC;
printf("Interface is %s.n",ifr.ifr_name);
if (ioctl(sock, SIOCSIFFLAGS, &ifr) == -1)
{
DIE("Second ioctl failed.n");
}
printf("Interface %sn",ifr.ifr_name);      // 这里用 $ifconfig eth1 查看网卡 属性,成功设置混杂模式

char buff[BUFF_SIZE];
socklen_t sock_len = sizeof(buff);

printf("Begin capture.n");
while (true)
{
printf("peek.n");
memset(buff, 0, sizeof(char) * sock_len);
               
                // 问题就在这里,一直阻塞,没有任何返回值
sock_len = recvfrom(
sock ,buff ,sizeof(buff) ,0 ,(sockaddr *)&addr_in ,&sock_len);
buff[sock_len] = '';
  printf("%sn",buff);
}

return 0;
}
搞了几天了,搞不定.
谢谢

|
28.4 Raw Socket Input

The first question that we must answer regarding raw socket input is: Which 
received IP datagrams does the kernel pass to raw sockets? The following rules 
apply:
      Received UDP packets and received TCP packets are never passed to a raw 
socket. If a process wants to read IP datagrams containing UDP or TCP packets,
 the packets must be read at the datalink layer, as described in Chapter 29.

---------------UNPv2

    
 
 

您可能感兴趣的文章:

  • Linux下read函数默认到底是阻塞的还是非阻塞的?
  • linux 如何用SOCKET设置函数设置阻塞和非阻塞?
  • linux C socke编程 创建的socket默认是阻塞的还是非阻塞的?
  • 请问:我发现在linux上的网络编程时, 若客户端连不上服务端,就会阻塞,但如果是在UNIX上,若连不上,会马上返回,并不阻 塞,怎样让它也能阻塞啊?
  • linux fwrite 阻塞问题
  • linux多线程无法进行阻塞方式的读写操作
  • linux下socket的send函数阻塞问题?
  • Linux里的pthread_create会不会阻塞啊?
  • linux socket fd 写阻塞问题
  • Linux系统刚启动起来的时候为什么会阻塞一下?
  • linux shell如何非阻塞写命名管道
  • linux sem_wait 为什么会阻塞进程?
  • linux下消息队列不阻塞
  • 如何linux 程序中启用其他进程,非阻塞,非popen
  • Linux线程阻塞问题 高手请进
  • linux多线程无法进行阻塞方式的读写操作?
  • linux下如何设置一个socket为非阻塞方式?
  • 在Linux下如何等待线程终止,又不会阻塞
  • linux下的非阻塞读取
  • linux epoll的ET模式和LT模式的主要区别是什么呢?为什么ET模式一定要用非阻塞socket?
  • Linux下的recvfrom为什么一直阻塞
  • linux下udp的recvfrom问题,大神,我需要你。。。
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux 下无限上网,用哪种可以?
  • 虚拟主机Linux(Ubuntu9.10)连接主机 的路由器Or无限网卡上网方法
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 论坛 iis7站长之家
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • linux命令大全详细分类介绍及常用linux命令文档手册下载
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在没有linux的盘,只有DOS启动盘)
  • Linux Kernel 'sctp_v6_xmit()'函数信息泄露漏洞
  • 如何让win2000和linux共存。我装好WIN2000,再装LINUX7.0,但LILO只能找到LINUX,不能引导WIN2000
  • linux c下利用srand和rand函数生成随机字符串
  • 在windows中的VMware装了个linux,主板有两个串口,能做windows和linux的串口通信测试么,怎么测试这两个串口在linux是有效
  • Linux c++虚函数(virtual function)简单用法示例代码
  • 我们网站的服务器从windows2000迁往linux,ASP程序继续使用,可是我连LINUX的皮毛都不了解,大家告诉我LINUX下怎么建网站??
  • Docker官方镜像将会使用Alpine Linux替换Ubuntu
  • 中文Linux与西文Linus分别哪一个版是权威?I认为是:中科软的白旗Linux与西文的绿帽子Linux!大家的看法呢?
  • Linux下chmod命令详细介绍及用法举例
  • 我重装了winme,却进不了Linux了,而我现在又没有Linux光盘,也没有Linux启动盘,还有没有办法?


  • 站内导航:


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

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

    浙ICP备11055608号-3