libcap编程 01

介绍

libcap是一个网络数据包捕获函数库,功能非常强大,是由劳伦斯伯克利实验室的网络研究小组开发者开发实现,其功能类似WinPcap,提供了应用层API给开发人员实现数据包的过滤和嗅探功能。Linux下著名的tcpdump就是以其为基础开发的。

libcap主要作用:

libcap的抓包框架:

利用libcap函数库开发应用程序的步骤:

安装

yum install libpcap-devel

编译

$GCC -o $PROG $OBJ -lpcap

接口介绍

char error_content[PCAP_ERRBUF_SIZE] = {0}; /* 出错信息 */
char *dev = pcap_lookupdev(error_content);
if(NULL == dev)
{
	printf(error_content);
	exit(-1);
}
char error_content[PCAP_ERRBUF_SIZE] = {0}; /* 出错信息 */
char *dev = pcap_lookupdev(error_content);
if(NULL == dev)
{
	printf(error_content);
	exit(-1);
}

bpf_u_int32 netp = 0, maskp = 0;
pcap_t * pcap_handle = NULL;
int ret = 0;

/*获得网络号和掩码*/
ret = pcap_lookupnet(dev, &netp, &maskp, error_content);
if(ret == -1)
{
	printf(error_content);
	exit(-1);
}
char error_content[PCAP_ERRBUF_SIZE] = {0}; /* 出错信息*/
char *dev = pcap_lookupdev(error_content); /* 获取网络接口 */
if(NULL == dev)
{
 printf(error_content);
 exit(-1);
}

/* 打开网络接口 */
pcap_t * pcap_handle = pcap_open_live(dev, 1024, 1, 0, error_content);
if(NULL == pcap_handle)
{
 printf(error_content);
 exit(-1);
}
struct pcap_pkthdr {
	struct timeval ts;//抓到包的时间
	bpf_u_int32 caplen;//抓到的数据的长度
	bpf_u_int32 len;//表示数据包的实际长度
}

返回值: 成功返回捕获数据的地址,失败返回NULL

void callback(u__char *userarg, const struct pcap_pkthdr *pkthdr, const u_char *packet)

示例

#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], * devStr;
  
  /* get a device */
  devStr = pcap_lookupdev(errBuf);
  
  if(devStr)
  {
    printf("success: device: %s\n", devStr);
  }
  else
  {
    printf("error: %s\n", errBuf);
    exit(1);
  }
  
  /* open a device, wait until a packet arrives */
  pcap_t * device = pcap_open_live(devStr, 65535, 1, 0, errBuf);
  
  if(!device)
  {
    printf("error: pcap_open_live(): %s\n", errBuf);
    exit(1);
  }
  
  /* construct a filter */
  struct bpf_program filter;
  pcap_compile(device, &filter, "dst port 80", 1, 0);
  pcap_setfilter(device, &filter);
  
  /* wait loop forever */
  int id = 0;
  pcap_loop(device, -1, getPacket, (u_char*)&id);
  
  pcap_close(device);

  return 0;
}

参考