UBUNTU下安装LIBPCAP+测试安装

[UBUNTU下安装LIBPCAP+测试安装]

安装

1 安装GCC

sudo apt-get install build-essential

2 安装GNU M4

下载地址:ftp://ftp.gnu.org/gnu/m4/
sudo tar -zxvf m4-latest.tar.gz
cd m4-1.4.17
sudo ./configure
sudo make
sudo make install

3.安装 flex

sudo apt-get install flex

4.安装bison

sudo apt-get install bison

5.安装libpcap

从网址http://www.tcpdump.org/ ,下载1.40版本 wget http://www.tcpdump.org/release/libpcap-1.4.0.tar.gz 
tar -zxvf libpcap-1.4.0.tar.gz
cd libpcap-1.4.0
sudo ./configure
sudo make
sudo make install

测试

可通过pcap_compile设置过滤规则,通过手动输入数字选择网卡设备

#include <pcap.h>
#include <time.h>
#include <stdlib.h>
#include <stdio.h>
 
void getPacket(u_char * arg, const struct pcap_pkthdr * pkthdr, const u_char * packet)
{
    int * id = (int *)arg;

    printf("id: %d\n", ++(*id));
    printf("Packet length: %d\n", pkthdr->len);
    printf("Number of bytes: %d\n", pkthdr->caplen);
    printf("Recieved time: %s", ctime((const time_t *)&pkthdr->ts.tv_sec)); 

    int i;
    for(i=0; i<pkthdr->len; ++i)
    {
        printf(" %02x", packet[i]);
        if( (i + 1) % 16 == 0 )
        {
            printf("\n");
        }
    }
    printf("\n\n");
}

 int main()
 {
     char errBuf[PCAP_ERRBUF_SIZE],*selectDevName;
     pcap_if_t *allDev,*selectDev;
     int iNum,i;

    /**
     * @brief 获取网络设备名称
     * 
     */
    if(pcap_findalldevs(&allDev,errBuf) == -1)
    {
        fprintf(stderr,"Error in pcap_findalldevs: %s\n", errBuf);
        exit(1);
    }
    for(selectDev=allDev; selectDev; selectDev=selectDev->next)
    {
        printf("%d. %s", ++i, selectDev->name);
        if (selectDev->description)
            printf(" (%s)\n", selectDev->description);
        else
            printf(" (No description available)\n");
    }

    printf(" (please input number for select devices)\n");
    scanf("%d", &iNum);
    for(selectDev=allDev, i=0; i< iNum-1 ;selectDev=selectDev->next, i++);

    selectDevName = selectDev->name;
    if(selectDevName)
    {
        printf("success: device: %s\n", selectDevName);
    }
    else
    {
        printf("error: %s\n", errBuf);
        exit(1);
    }

    /* open a device, wait until a packet arrives */
    pcap_t * device = pcap_open_live(selectDevName, 65535, 1, 0, errBuf);
    if(!device)
    {
        printf("error: pcap_open_live(): %s\n", errBuf);
        exit(1);
    }
    /* construct a filter */
    struct bpf_program filter;
    int filterState = pcap_compile(device, &filter, "dst port 80 and src host 192.168.1.159 and dst host 192.168.1.159 and src port 8080", 1, 0); //与或非用and or not
    printf("filterState: %d\n\n",filterState); //0--成功,-1--失败
    pcap_setfilter(device, &filter);

    /* wait loop forever */
    int id = 0;
    pcap_loop(device, -1, getPacket, (u_char*)&id);

    pcap_close(device);

    return 0;
 }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值