首页
社区
课程
招聘
[求助]关于获取远程MAC地址的代码
发表于: 2007-3-2 19:34 4711

[求助]关于获取远程MAC地址的代码

2007-3-2 19:34
4711
我知道调用sendarp就可以完成任务,我写的代码,结果大家都知道了,当然不成功拉,所以就上来问问 

.486
.model flat, stdcall
option casemap:none
include windows.inc
include kernel32.inc
include wsock32.inc
include iphlpapi.inc                                ;for SendARP
include user32.inc
includelib wsock32.lib
includelib kernel32.lib
includelib iphlpapi.lib
includelib user32.lib
.data
wsaData WSADATA<>
new_addr        sockaddr_in<>
szIP db "192.168.3.135",0
szMac                db        '%02X:%02X:%02X:%02X:%02X:%02X',0
szOut db 156 dup(0)
.data?
pulMAC        ULONG ?
ulLen                ULONG ?
hSocket SOCKET ?
.code
start:
invoke WSAStartup,202h,addr wsaData;初始化WSAStartup
mov hSocket,eax
invoke inet_addr,addr szIP;转换IP为十六进制模式
mov eax,new_addr.sin_addr.S_un.S_addr
lea ebx,ulLen
mov ebx,6 ;赋值到ulLen
push ebx
pop ulLen;addr ulLen=ebx=6
invoke SendARP,eax,NULL,addr pulMAC,addr ulLen;发送arp数据包
.if eax != NO_ERROR
invoke  wsprintf,addr szOut,addr szMac,pulMAC[1],pulMAC[2],pulMAC[3],pulMAC[4],pulMAC[5],pulMAC[6]
invoke MessageBox,NULL,addr szOut,NULL,MB_OK
.endif
invoke ExitProcess,NULL
end start

[课程]FART 脱壳王!加量不加价!FART作者讲授!

收藏
免费 0
支持
分享
最新回复 (3)
雪    币: 2134
活跃值: (14)
能力值: (RANK:170 )
在线值:
发帖
回帖
粉丝
2
invoke SendARP,eax,NULL,addr pulMAC,addr ulLen;发送arp数据包
2007-3-3 10:40
0
雪    币: 796
活跃值: (370)
能力值: ( LV9,RANK:380 )
在线值:
发帖
回帖
粉丝
3
这里出错了吗?
2007-3-3 10:42
0
雪    币: 2134
活跃值: (14)
能力值: (RANK:170 )
在线值:
发帖
回帖
粉丝
4
eax的值应该不对,另外不知道 addr 会不会修改eax

mov eax,new_addr.sin_addr.S_un.S_addr
这个去掉

还有.if eax != NO_ERROR
判断好像也是错误的,你 看看api的返回值是什么
2007-3-3 13:35
0
游客
登录 | 注册 方可回帖
返回
//