分享
 
 
 

利用ARP探测以太网中的活动主机

王朝other·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

网上存在很多关于ARP的文章,大多都是关于ARP欺骗,这里介绍ARP的另类用法:探测目标主机是否处于活动状态。

传统探测远程主机是否存活的方法是通过ICMP协议中的回显应答报文来探测(ping)。随着对安全的越来越多的了解和重视,很多主机为了避免被扫描器探测,通过防火墙将ICMP包屏蔽,从而达到在网络中隐藏的目的。

这里我们介绍一下利用ARP协议探测网络中的活动主机的思路,这种方法的缺点只能探测以太网内的活动主机。

先大概了解一下ARP协议。ARP协议是“Address Resolution Protocol”(地址解析协议)的缩写,它的作用是将IP地址转换成物理地址(就是常说的MAC地址),其详细过程参考《TCP/IP详解 卷一》。协议ARP的分组格式如下:

------------------------------------------

以太网目的地址(6个字节)

以太网源地址(6个字节)

帧类型(ARP = 0806)(2个字节)

------------------------------------------

硬件类型(Ethernet=01)(2个字节)

协议类型(IPv4=0800)(2个字节)

硬件地址长度(1个字节)

协议地址长度(1个字节)

OP操作选项(ARP request=01,ARP reply=02)(2个字节)

发送端以太网地址(6个字节)

发送端IP地址(4个字节)

目的以太网地址(6个字节)

目的IP地址(4个字节)

--------------------------------------------

我们向目标主机发送一个ARP请求,如果目标主机处于活动状态则会返回其MAC地址,如果对方返回MAC地址,则表明对方处于活动状态,这样达到探测目的。ARP请求包内容如下:

------------------------------------------

以太网目的地址

|FFFFFFFFFFFF(广播地址)

以太网源地址

|本地MAC地址

帧类型

|0806

------------------------------------------

硬件类型

|01

协议类型

|0800

硬件地址长度

|06

协议地址长度

|04

OP操作选项

|01

发送端以太网地址|本地MAC地址

发送端IP地址

|目标主机IP地址

目的以太网地址

|000000000000

目的IP地址

|目标主机IP地址

--------------------------------------------

注意:这里以太网目的地址为FFFFFFFFFFFF,这是广播地址,以太网上所有主机都能收到这个包,在收到这个数据包后,操作系统判断目的IP地址是不是这台主机,如果不是则丢弃(不作处理),否则发送回一个ARP应答包,包的内容如下:

------------------------------------------

以太网目的地址

|探测主机的MAC地址

以太网源地址

|本地MAC地址

(这里本地指被探测主机)

帧类型

|0806

------------------------------------------

硬件类型

|01

协议类型

|0800

硬件地址长度

|06

协议地址长度

|04

OP操作选项

|02

发送端以太网地址|本地MAC地址

(这里本地指被探测主机)

发送端IP地址

|本机IP地址

(这里本地指被探测主机)

目的以太网地址

|探测主机的MAC地址

目的IP地址

|探测主机的IP地址

--------------------------------------------

我们可以使用Pcap自己来构造这个数据包(具体过程参考Pcap的相关文档,这里我们使用SendARP()来实现),SendARP()是Microsoft Platform SDK中提供用来获得目标主机的MAC地址的函数,SendARPSendARP的函数原型如下:

DWORD SendARP(

IPAddr DestIP,

// 目标IP地址

IPAddr SrcIP,

// 源IP地址

PULONG pMacAddr,

// 返回MAC地址指针

PULONG PhyAddrLen

// 返回MAC地址长度

);

下面这个例子摘至MSND,稍做改动可以成为一个以太网内活动主机探测工具

//

// Link with ws2_32.lib and iphlpapi.lib

//

#include <windows.h

#include <stdio.h

#include <tchar.h

#include <iphlpapi.h

int __cdecl main()

{

HRESULT hr;

IPAddr

ipAddr;

ULONG

pulMac[2];

ULONG

ulLen;

ipAddr = inet_addr ("192.168.0.1");

memset (pulMac, 0xff, sizeof (pulMac));

ulLen = 6;

hr = SendARP (ipAddr, 0, pulMac, &ulLen);

printf ("Return %08x, length %8d\n", hr, ulLen);

size_t i, j;

char * szMac = new char[ulLen*3];

PBYTE pbHexMac = (PBYTE) pulMac;

//

// Convert the binary MAC address into human-readable

//

for (i = 0, j = 0; i < ulLen - 1; ++i) {

j += sprintf (szMac + j, "%02X:", pbHexMac[i]);

}

sprintf (szMac + j, "%02X", pbHexMac[i]);

printf ("MAC address %s\n", szMac);

delete [] szMac;

return 0;

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有