你好,欢迎来到! 设为首页 收藏本站
联系电话
论文范文 当前位置: > 写作指南 > 论文范文 >

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

时间:2015-08-31 09:52来源:核心期刊网 作者:核心期刊网 点击:
【摘要】:本文分析了利用SendARP方法(基于ARP协议)来获取远程主机MAC地址的缺陷,提出了一种新思路研究并利用NetBIOSNameService来快速获取远程主机MAC地址的方法,并给出了其在BorlandDelphi6中的程序。 【关键词】:MAC地址,远程主机,NetBIOS,TNMUDP
  【摘要】:本文分析了利用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;


  核心期刊网(www.hexinqk.com)秉承“诚以为基,信以为本”的宗旨,为广大学者老师提供投稿辅导、写作指导、核心期刊推荐等服务。
  核心期刊网专业期刊发表机构,为学术研究工作者解决北大核心CSSCI核心统计源核心EI核心等投稿辅导咨询与写作指导的问题。

  投稿辅导咨询电话:18915033935
  投稿辅导客服QQ: 论文投稿1002080872 论文投稿1003158336
  投稿辅导投稿邮箱:1003158336@qq.com
------分隔线----------------------------
栏目列表  
推荐论文  
热点论文  
 
QQ在线咨询
投稿辅导热线:
189-1503-3935
微信号咨询:
18915033935
网站简介 核刊总览 普刊专栏 期刊验证 学术答疑 服务流程 写作指南 支付方式 信用说明 联系我们
CopyRight © 2013 All Rights Reserved.
免责声明:本站提供投稿辅导 论文投稿 投稿辅导 核心期刊检索 核心投稿辅导等服务,本站刊载文章仅代表作者观点
并不意味着本站认同,部分作品系转载,版权归原作者或相应的机构;若某篇作品侵犯您的权利,请来信告知:1003158336@qq.com