网络编程中利用结构体方式组包(以arp攻击为例)

一、逐个元素组包

//msg存放arp应答报文
	unsigned char msg[]={
		/*mac头部(14个字节)*/
		0x70,0x5A,0x0F,0x63,0xF5,0x9D,	 /*目的mac地址(xp的mac))*/
		0x00,0x00,0x00,0x00,0x00,0x00,	 /*源mac地址(伪装的mac)*/
		0x08,0x06,						 /*帧类型*/
		
		/*ARP报文头部(28个字节)*/
		0x00,0x01,						 /*硬件类型*/	
		0x08,0x00,						 /*协议类型*/
		6,								 /*硬件地址长度*/
		4,								 /*协议地址长度*/
		0x00,0x02,						 /*ARP应答*/
		0x00,0x00,0x00,0x00,0x00,0x00,	 /*源ac地址(伪装的mac)*/
		192,168,0,111,				     /*源IP(ubuntu的IP地址)*/
		0x70,0x5A,0x0F,0x63,0xF5,0x9D,	 /*目的mac地址(XP的mac)*/
		192,168,0,110	 			 	 /*目的IP*/
	};

二、利用结构体方式组包

以太网头部
在这里插入图片描述
在这里插入图片描述
ARP头部
使用的时候需要在/usr/include/net/if_arp.h中将arphdr结构体中的#if 0改为1
在这里插入图片描述

//组arp应答报文msg(mac头部+arp头部)
	
	unsigned char dst_mac[6]={0x70,0x5A,0x0F,0x63,0xF5,0x9D,};//目的mac地址(xp的mac))
	unsigned char src_mac[6]={0x00};						  //源mac地址
	unsigned char src_ip[4]={192,168,0,111};				  //源IP
	unsigned char dst_ip[4]={192,168,0,110};                  //目的IP

	unsigned char msg[1024]="";
	//1.组mac头部
	struct ether_header *eth_addr = (struct ether_header *)msg;
	//赋值mac地址
	memcpy(eth_addr->ether_dhost, dst_mac, 6);
	memcpy(eth_addr->ether_shost, src_mac, 6);
	//赋值帧类型
	eth_addr->ether_type = htons(0x0806);
	
	//2.组arp头部
	struct arphdr *arp_head = (struct arphdr *)(msg+14);	//跳过mac头的空间
	arp_head->ar_hrd = htons(1);			//硬件类型
	arp_head->ar_pro = htons(0x0800);		//协议类型
	arp_head->ar_hln = 6;					//硬件地址长度(一个字节不存在大小端,不需要用htons)
	arp_head->ar_pln = 4;					//协议地址长度
	arp_head->ar_op  = htons(2);			//arp应答
	memcpy(arp_head->__ar_sha, src_mac, 6);	//源mac
	memcpy(arp_head->__ar_sip, src_ip, 4);	//源ip
	memcpy(arp_head->__ar_tha, dst_mac, 6);	//目的mac
	memcpy(arp_head->__ar_tip, dst_ip, 4);	//目的ip	
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值