简单抓包代码(链路层)

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/socket.h> /*含socket函数的定义*/
#include <sys/types.h>
#include <sys/ioctl.h>
//#include <netinet/in.h>//含struct sockaddr_in的定义,下面程序没有用到。可删
#include <netinet/ip.h>/*含struct iphdr*/
#include <netinet/if_ether.h>/*含struct ethhdr*/
#include <net/if.h>/* 含struct ifreq 的定义。请球结构*/
#define oops(msg){perror(msg);exit(0);}
int main(int ac,char**av)
{
    struct iphdr *iph;
    struct ethhdr *eth;
    char buffer[2048];
    int sockfd;
    if((sockfd=socket(AF_PACKET,SOCK_RAW,htons(ETH_P_IP)))<0)
    oops("socket");
    int nbytes=0;
    ///
    //把这段去掉,就是在普通下抓自己的包,很简单的代码,只需要
    //生成一个原始套接子就可以了,然后套接子也不用绑定网卡(ip)
    //它会去所有的网卡都抓过来。
    /*把套接字和网卡(eth0 or any name )绑定,且把网卡设为混杂模式*/
    struct ifreq ethreq;
    strncpy(ethreq.ifr_name,"wlan0",IFNAMSIZ);
    if((ioctl(sockfd,SIOCGIFFLAGS,ðreq))<0)
    oops("io get");
    ethreq.ifr_flags|=IFF_PROMISC;
    if((ioctl(sockfd,SIOCSIFFLAGS,ðreq))<0)
    oops("io set");
    //
    while(1)
    {
     if((nbytes=recvfrom(sockfd,buffer,sizeof(buffer),0,NULL,NULL))<0)
         oops("recvfrom");
     printf("recefrom %d bytes\n",nbytes);

     eth=(struct ethhdr*)buffer;
     int i;
     printf("Mac source addr:");
     for(i=0;i<6;i++)
         printf("%x: ",eth->h_source[i]);
     printf("\n");

     printf("Mac dest addr:");
     for(i=0;i<6;i++)
         printf("%x: ",eth->h_dest[i]);
     printf("\n");
    
     iph=(struct iphdr*)(buffer+sizeof(struct ethhdr));
     printf("ip src:%s\n",inet_ntoa(iph->saddr));
     printf("ip dst:%s\n",inet_ntoa(iph->daddr));
    }
    return 0;
}
    

    








评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值