获取远程主机MAC地址的新思路及实现

时间:2015-08-31 09:52 来源:发表吧 作者:发表吧编辑 点击:
  【摘要】:本文分析了利用SendARP方法(基于ARP协议)来获取远程主机MAC地址的缺陷,提出了一种新思路——研究并利用NetBIOSNameService来快速获取远程主机MAC地址的方法,并给出了其在BorlandDelphi6中的程序。
  【关键词】:MAC地址,远程主机,NetBIOS,TNMUDP
  1引言
  众所周知,在所有网卡信息中,最重要的莫过于网卡的MAC地址,即网卡的物理地址。MAC地址固化在网卡的ROM中,一般不易改动。因此在网络中需要监控一台计算机的最好的方法就是获取它的MAC地址。
  那么,如何获取远程主机(RemoteHost,即和本地主机不在同一个子网中的主机)的MAC地址呢?一般的资料认为:采用IpHelperAPI的SendARP方法,但根据笔者的实验观察,此种方法行不通——它只能获取“本网段”内主机的MAC地址,如果源主机与目的主机不在同一个网段内,则该方法就只能获取“网关”的MAC地址,而无法获取目的主机的MAC地址。这是由ARP协议的工作原理决定的。
  2获取远程主机MAC地址的原理及分析
  下面是利用NetBIOS协议来获取“远程主机(Remotehost)”MAC地址的思路和实现方法。
  大家都知道,NetBIOS(网络基本输入/输出系统)是一套用于网络通讯的调用接口,包含了NetBIOSName和MAC地址等信息。NetBIOS并没有对下层使用的协议进行限制,因此它除了可以在NetBEUI支持下运行之外,还可以在其他协议支持下运行。其中NetBIOSOverIP由于使用TCP/IP协议,使远程主机之间的NetBIOS通信得以较好实现。
  在NetBIOSOverIP通信过程中,可假定源主机A向远程目的主机B请求其“NetBIOSNames”信息。则两者之间的通信过程如下所示:
  首先,主机A向主机B发送“UDP-NetBIOS-NS”询问包,即向主机B的137端口,发Query包来询问主机B的NetBIOSNames信息。
  其次,主机B接收到“UDP-NetBIOS-NS”询问包,假设主机B正确安装了NetBIOS服务,而且137端口开放,则主机B会向主机A发送一个“UDP-NetBIOS-NS”应答包,即发Answer包给主机A。
  分析主机B反馈给主机A的Answer包可知:其中不仅包含了主机B的NetBIOSName信息,且包含了主机B的MAC地址。“UDP-NetBIOS-NS”应答包的结构及主要字段如下:
  表1“UDP-NetBIOS-NS”应答包的结构及主要字段一览表
  序号字段名长度
  1TransactionID两字节(16位)
  2Flags两字节(16位)
  3Questions两字节(16位)
  4AnswerRRs两字节(16位)
  5AuthorityRRs两字节(16位)
  6AdditionalRRs两字节(16位)
  7Name<Workstation/Redirector>34字节(272位)
  8Type:NBSTAT两字节(16位)
  9Class:INET两字节(16位)
  10TimeToLive四字节(32位)
  11Length两字节(16位)
  12Numberofname一个字节(8位)
  NetBIOSNameInfo18×NumberOfName字节
  UnitID6字节(48位)
  …
  其中,关键字段“UnitID”(6字节)就是主机B的MAC地址。
  因此可以设想:本地主机构造“UDP-NetBIOS-NS”询问包,并发送给远程主机,然后再接收“UDP-NetBIOS-NS”应答包,并对其分析以提取出远程主机的MAC地址,这样就可以获取“远程主机”的MAC地址。
  3获取远程主机MAC地址的实现
  所以构造“UDP-NetBIOS-NS”询问包,其结构如下:
  typetNetBiosNS=record
  tID:word;
  Flags:word;
  Questions:word;
  AnswerRRs:word;
  AuthorityRRs:word;
  AdditionalRRs:word;
  Name:array[1..34]ofbyte;
  tType:word;
  tClass:word;
  end;
  利用Delphi6.0中的TNMUDP组件——它是用来实现在Internet或Intranet上发送或接收UDP的。接下来把这样的“询问包”放置到UDP的数据部分,再将其发出到远程主机。则可坐等“应答包”。
  根据应答包的格式(见表1),可计算出“UnitID”字段在UDP包的数据部分的位置:先从第56字节位置,读出NumberOfNames(NetBIOS名字的个数,其中每个NetBIOSNamesInfo部分占18个字节),然后可计算出“UnitID”字段的位置=56+NumberOfNames×18,最后从该位置起连续读取6个字节,就是目的主机的MAC地址。
  下面给出了在BorlandDelphi6中的实现“获取远程主机MAC地址”的主要代码。
  procedureTForm1.Button2Click(Sender:TObject);//发送“UDP-NetBIOS-NS”询问包
  var
  MyStream:TMemoryStream;
  t_ns:tNetBiosNS;
  i:byte;
  begin
  witht_nsdo
  begin
  tID:=$0000;
  Flags:=$1000;
  Questions:=$0100;
  AnswerRRs:=$0000;
  AuthorityRRs:=$0000;
  AdditionalRRs:=$0000;
  Name[1]:=$20;
  Name[2]:=$43;
  Name[3]:=$4b;

www.fabiaoba.com),是一个专门从事期刊推广期刊发表、投稿辅导、发表期刊的网站。
  本站提供如何投稿辅导、发表期刊,寻求论文刊登合作,快速投稿辅导,投稿辅导格式指导等解决方案:省级论文刊登/国家级论文刊登/ CSSCI核心/医学投稿辅导/职称投稿辅导。

投稿邮箱:fabiaoba365@126.com
 在线咨询: 投稿辅导275774677投稿辅导1003180928
 在线咨询: 投稿辅导610071587投稿辅导1003160816
 联系电话:18796993035

联系方式
李老师QQ:发表吧客服610071587 陈老师QQ:发表吧客服275774677 刘老师QQ:发表吧客服1003160816 张老师QQ:发表吧客服1003180928 联系电话:18796993035 投稿邮箱:fabiaoba365@126.com
期刊鉴别
  • 刊物名称:
  • 检索网站:
热门期刊
发表吧友情提醒

近来发现有些作者论文投稿存在大量剽窃、抄袭行为,“发表吧”对此类存在大量剽窃、抄袭的论文已经停止编辑、推荐。同时我们也提醒您,当您向“发表吧”投稿时请您一定要保证论文的原创性、唯一性,这既是对您自己负责,更是对他人的尊敬。

此类投稿的论文如果发表之后,对您今后的人生和事业将造成很大的麻烦,后果不堪设想,请您一定要慎重,三思而后行。

如因版权问题引起争议或任何其他原因,“发表吧”不承担任何法律责任,侵权法律责任概由剽窃、抄袭者本人承担。

 
QQ在线咨询
论文刊登热线:
137-7525-9981
微信号咨询:
fabiaoba-com

友情链接

申请链接