标签:发送数据包
【实验代码】
// sendpacket.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <stdlib.h>
#include <stdio.h>
#include <pcap.h>
void main(int argc, char **argv)
{
pcap_t *fp;
pcap_if_t *d;
pcap_if_t *alldevs;
int inum;
char errbuf[PCAP_ERRBUF_SIZE];
u_char packet[100];
int i;
int i2=0;
/* 获得设备列表 */
if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL, &alldevs, errbuf) == -1)
{
fprintf(stderr,"Error in pcap_findalldevs: %s\n", errbuf);
exit(1);
}
/* 打印列表 */
for(d=alldevs; d; d=d->next)
{
printf("%d. %s", ++i2, d->name);
if (d->description)
printf(" (%s)\n", d->description);
else
printf(" (No description available)\n");
}
if(i2==0)
{
printf("\nNo interfaces found! Make sure WinPcap is installed.\n");
return ;
}
printf("Enter the interface number (1-%d):",i2);
scanf("%d", &inum);
if(inum < 1 || inum > i2)
{
printf("\nInterface number out of range.\n");
/* 释放设备列表 */
pcap_freealldevs(alldevs);
return ;
}
/* 跳转到已选设备 */
for(d=alldevs, i2=0; i2< inum-1 ;d=d->next, i2++);
/* 打开输出设备 */
if ( (fp= pcap_open(d->name, // 设备名
100, // 要捕获的部分 (只捕获前100个字节)
PCAP_OPENFLAG_PROMISCUOUS, // 混杂模式
1000, // 读超时时间
NULL, // 远程机器验证
errbuf // 错误缓冲
) ) == NULL)
{
fprintf(stderr,"\nUnable to open the adapter. %s is not supported by WinPcap\n", argv[1]);
return;
}
/* 释放设备列表 */
pcap_freealldevs(alldevs);
/* 假设在以太网上,设置MAC的目的地址为 1:1:1:1:1:1 */
packet[0]=255;
packet[1]=255;
packet[2]=255;
packet[3]=255;
packet[4]=255;
packet[5]=255;
/* 设置MAC源地址为 2:2:2:2:2:2 */
packet[6]=7;
packet[7]=7;
packet[8]=7;
packet[9]=7;
packet[10]=7;
packet[11]=7;
packet[12]=96;
packet[13]=00;
/* 填充剩下的内容 */
for(i=14;i<100;i++)
{
packet[i]=i%256;
}
/* 发送数据包 */
if (pcap_sendpacket(fp, packet, 100 /* size */) != 0)
{
fprintf(stderr,"\nError sending the packet: \n", pcap_geterr(fp));
return;
}
return;
}
【实验结果】
在wireshark中检索eth.type==9600
就会出现所输入的地址
本文出自 “青人云囚” 博客,谢绝转载!
标签:发送数据包
原文地址:http://12044860.blog.51cto.com/12034860/1873528