- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
使用Wincap编制一个简单的网络数据包监听与捕获程序
实验目的
二、实验内容
要求使用Wincap编制一个简单的网络数据包监听与捕获程序,同时,将捕获的数据包进行分析并将分析结果显示在屏幕上。
实验步骤、记录和结果
代码如下:
#include pcap.h
typedef struct{
int number;
char name[10];
}Protocol;
Protocol protocol[10];
/* 4字节的IP地址 */
typedef struct ip_address{
u_char byte1;
u_char byte2;
u_char byte3;
u_char byte4;
}ip_address;
/* IPv4 首部 */
typedef struct ip_header{
u_char ver_ihl; // 版本 (4 bits) + 首部长度 (4 bits)
u_char tos; // 服务类型(Type of service)
u_short tlen; // 总长(Total length)
u_short identification; // 标识(Identification)
u_short flags_fo; // 标志位(Flags) (3 bits) + 段偏移量(Fragment offset) (13 bits)
u_char ttl; // 存活时间(Time to live)
u_char proto; // 协议(Protocol)
u_short crc; // 首部校验和(Header checksum)
ip_address saddr; // 源地址(Source address)
ip_address daddr; // 目的地址(Destination address)
u_int op_pad; // 选项与填充(Option + Padding)
}ip_header;
/* 回调函数原型 */
void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data);
int main()
{
pcap_if_t *alldevs;
pcap_if_t *d;
int inum;
int i=0;
pcap_t *adhandle;
char errbuf[PCAP_ERRBUF_SIZE];
u_int netmask;
//char packet_filter[] = ip and udp;
char packet_filter[] = ip;
struct bpf_program fcode;
protocol[0].number = 1; strcpy(protocol[0].name, ICMP);
protocol[1].number = 2; strcpy(protocol[1].name, IGMP);
protocol[2].number = 4; strcpy(protocol[2].name, IP);
protocol[3].number = 6; strcpy(protocol[3].name, TCP);
protocol[4].number = 8; strcpy(protocol[4].name, EGP);
protocol[5].number = 9; strcpy(protocol[5].name, IGP);
protocol[6].number = 17; strcpy(protocol[6].name, UDP);
protocol[7].number = 41; strcpy(protocol[7].name, IPv6);
protocol[8].number = 50; strcpy(protocol[8].name, ESP);
protocol[9].number = 89; strcpy(protocol[9].name, OSPF);
/* 获得设备列表 */
if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL, alldevs, errbuf) == -1)
{
fprintf(stderr,Error in pcap_findalldevs: %s\n, errbuf);
exit(1);
您可能关注的文档
最近下载
- 黑臭河道整治工程施工组织设计.doc VIP
- 天一大联考海南省2025—2026学年高三学业水平诊断(一)政治(含答案).docx
- 坑塘治理施工方案.docx VIP
- 猪、牛、羊定点屠宰项目环评(新格式)环境影响报告表.pdf VIP
- 2025美国心脏协会和美国儿科学会新生儿复苏、儿童基础生命支持和儿童高级生命支持指南更新解读.pptx VIP
- 工程流体力学名词解释和简答题大全.docx
- 大众奥迪诊断系统ODIS7.21用户手册.pdf VIP
- 小学数学与科学跨学科课程融合人工智能的实践研究教学研究课题报告.docx
- 福建奔驰-威霆-产品使用说明书-威霆 2013款 3.0L-FA6523-威霆用户手册.pdf VIP
- 闭合导线计算表(自动计算).xls VIP
原创力文档


文档评论(0)