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

来源 :电脑知识与技术 | 被引量 : 0次 | 上传用户:kkkhorse
下载到本地 , 更方便阅读
声明 : 本文档内容版权归属内容提供方 , 如果您对本文有版权争议 , 可与客服联系进行内容授权或下架
论文部分内容阅读
  摘要:该文分析了利用SendARP方法(基于ARP协议)来获取远程主机MAC地址的缺陷,提出了一种新思路——研究并利用NetBIOS Name Service来快速获取远程主机MAC地址的方法,并给出了其在Borland Delphi6中的程序。
  关键词:MAC地址;远程主机;NetBIOS;TNMUDP
  中图分类号:TP3文献标识码:A文章编号:1009-3044(2008)36-2580-02
  MAC Address of the Remote Access Host of New Ideas and Achieve
  CONG Liang
  (Jilin New Station Tuberculosis Hospital, Jilin 132000, China)
  Abstract: This paper analyzes the use of the method SendARP (based on the agreement ARP) to obtain the MAC address of remote host defects, a new train of thought - to study and use of NetBIOS Name Service for rapid access to remote host MAC address of the way and gives Borland Delphi6 in its procedures.
  Key words: MAC address; remote host; NetBIOS; TNMUDP
  
  1 引言
  众所周知,在所有网卡信息中,最重要的莫过于网卡的MAC地址,即网卡的物理地址。MAC地址固化在网卡的ROM中,一般不易改动。因此在网络中需要监控一台计算机的最好的方法就是获取它的MAC地址。
  那么,如何获取远程主机的MAC地址呢?一般的资料认为:采用IpHelperAPI的SendARP方法,但根据笔者的实验观察,此种方法行不通——它只能获取“本网段”内主机的MAC地址,如果源主机与目的主机不在同一个网段内,则该方法就只能获取“网关”的MAC地址,而无法获取目的主机的MAC地址。这是由ARP協议的工作原理决定的。
  2 获取远程主机MAC地址的原理及分析
  下面是利用NetBIOS协议来获取“远程主机(Remote host)”MAC地址的思路和实现方法。
  大家都知道,NetBIOS(网络基本输入/输出系统)是一套用于网络通讯的调用接口,包含了NetBIOS Name和MAC地址等信息。NetBIOS并没有对下层使用的协议进行限制,因此它除了可以在NetBEUI支持下运行之外,还可以在其他协议支持下运行。其中NetBIOS Over IP由于使用TCP/IP协议,使远程主机之间的NetBIOS通信得以较好实现。
  在NetBIOS Over IP通信过程中,可假定源主机A向远程目的主机B请求其“NetBIOS Names”信息。则两者之间的通信过程如下所示:
  首先,主机A向主机B发送“UDP-NetBIOS-NS”询问包,即向主机B的137端口,发Query包来询问主机B的NetBIOS Names信息。
  其次,主机B接收到“UDP-NetBIOS-NS”询问包,假设主机B正确安装了NetBIOS服务,而且137端口开放,则主机B会向主机A发送一个“UDP-NetBIOS-NS”应答包,即发Answer包给主机A。
  分析主机B反馈给主机A的Answer包可知:其中不仅包含了主机B的NetBIOS Name信息,且包含了主机B的MAC地址。
  3 获取远程主机MAC地址的实现
  所以构造 “UDP-NetBIOS-NS”询问包,其结构如下:
  type tNetBiosNS=record
  tID:word;
  Flags:word;
  Questions:word;
  AnswerRRs:word;
  AuthorityRRs:word;
  AdditionalRRs:word;
  Name:array [1..34] of byte;
  tType:word;
  tClass:word;
  end;
  利用Delphi6.0中的TNMUDP组件——它是用来实现在Internet或Intranet上发送或接收UDP的。接下来把这样的“询问包”放置到UDP的数据部分,再将其发出到远程主机。则可坐等“应答包”。
  根据应答包的格式(见表1),可计算出“Unit ID”字段在UDP包的数据部分的位置:先从第56字节位置,读出Number Of Names(NetBIOS名字的个数,其中每个NetBIOS Names Info部分占18个字节),然后可计算出“Unit ID”字段的位置=56+Number Of Names×18,最后从该位置起连续读取6个字节,就是目的主机的MAC地址。
  下面给出了在Borland Delphi6中的实现“获取远程主机MAC地址”的主要代码。
  procedure TForm1.Button2Click(Sender: TObject); //发送“UDP-NetBIOS-NS”询问包
  var
  MyStream:TMemoryStream;
  t_ns:tNetBiosNS;
  i:byte;
  begin
  with t_ns do
  begin
  tID:=$0000;
  Flags:=$1000;
  Questions:=$0100;
  AnswerRRs:=$0000;
  AuthorityRRs:=$0000;
  AdditionalRRs:=$0000;
  Name[1]:=$20;
  Name[2]:=$43;
  Name[3]:=$4b;
  for i:=4 to 33 do
  Name:=$41;
  Name[34]:=$00;
  tType:=$2100;
  tClass:=$0100;
  end;
  nmudp1.LocalPort:=3000;//UDP绑定的本地主机的端口
  nmudp1.RemoteHost:=edit1.Text;
  nmudp1.RemotePort:=137;// NetBIOS-NS ,137端口
  MyStream:=TmemoryStream.Create;
  try
  MyStream.Write(t_ns, sizeof(t_ns));
  NMUDP1.SendStream(MyStream);
  finally
  MyStream.Free;
  end;
  end;
  下面是接收发送“UDP-NetBIOS-NS”应答包并分析和显示处理结果的代码。
  procedure TForm1.NMUDP1DataReceived(Sender: TComponent;
  NumberBytes: Integer; FromIP: String; Port: Integer);
  var
  MyStream:TMemoryStream;
  mac_str:array[1..6]of byte;
  NumOfNames:byte;
  begin
  if numberbytes>0 then //如果接收的数据包字节数>0,则处理数据包
  begin
  MyStream:=TmemoryStream.Create;
  try
  NMUDP1.readstream(MyStream); //把接收到的数据包,读到内存中
  MyStream.Seek(56,SoFromBeginning);//定位至Number Of Names字段
  MyStream.Read(NumOfNames,1); //获取 Number Of Names字段的值
  MyStream.Seek(NumOfNames*18,soFromCurrent); //定位至Unit ID字段
  MyStream.Read(mac_str[1],6); //獲取Unit ID字段的值
  edit4.Text:=inttohex(mac_str[1],2) ’-’ //将目的主机的MAC地址格式化输出
  inttohex(mac_str[2],2) ’-’
  inttohex(mac_str[3],2) ’-’
  inttohex(mac_str[4],2) ’-’
  inttohex(mac_str[5],2) ’-’
  inttohex(mac_str[6],2);
  finally
  MyStream.Free;
  end;
  end;
  end;
  4 结束语
  这种方法的优点是:获取(扫描)MAC地址的效率较高。(下转第2586页)
  (上接第2581页)
  一般针对某远程主机一次发送一个“UDP-NetBIOS-NS”询问包(当然具体发送几个,可以在程序中自己设定)即可,而不像其他也可获取MAC地址的方法,例如Winsock API函数Gethostbyaddr或者Netbios函数,执行的时候会发送多个“UDP-NetBIOS-NS”询问包,这样不但影响了获取速度,而且重复发送没必要。
  当然,该方法除了可以获取MAC地址外,还可以很容易地获取远程主机的NetBIOS Name信息(即主机名、所在工作组等)。而且在本程序的基础上,也很容易地实现对指定IP地址段的MAC地址扫描,即批量获取MAC地址,不再赘述。
  
  参考文献:
  [1] Anthony Jones.Windows网络编程技术[M].北京:机械工业出版社.2000.
  [2] 王鹏.基于.NET框架下即时通信系统的研究与实现[D].哈尔滨工程大学,2007.
其他文献
在马平的中篇小说《我看日出的地方》(载《人民文学》2019年第9期,后选入《小说选刊》2019年第11期)里,主人公春早去找寻紫薇树时有这么一段场景描述:“大道两旁挤满了大树,即便不下雪,也没有什么空隙可以望见四周的山峦”——那么多“山高黃桶粗的大树”跑到这儿来集合,“一棵树的亲人们找来了”。然而,参天大树林荫盛密足可蔽日,但却囚于园中待价而沽。作者用一棵来自大巴山的大树撑起了他和乡民们壮丽还乡的
儿童语言教育在幼儿教育体系中发挥着重要的作用,良好的语言教学活动是幼儿感知世界的基础条件之一。中国海洋大学出版社出版、贾素宁和李广兴所著的《学前儿童语言教育活动设计与指导》一书,在详细分析学龄前儿童语言发展特点与幼儿教育体系结构的基础上,提出了从儿童文化的角度来设计与组织儿童语言教学活动,同时还要求教师要在每次幼儿语言活动结束之后进行有效的评价。  《学前儿童语言教育活动设计与指导》共有三部分内容
摘要:教学质量信息员在已成为高校教学质量监控的中坚力量,而良好的信息反馈与沟通方式影响着信息员作用的发挥。信息员提供的信息范围广、数量多导致信息周期长、效率低下,甚至部分信息得不到有效的反馈。该文设计的基于.NET的高校教学质量信息员管理系统将有效地解决这一问题,它具备完善的信息录入、管理、统计、采编和发布等功能。  关键词:教学质量; 教学信息员; 管理系统  中图分类号:TP311文献标识码:
故事续编写话教学模式是集美大学施茂枝教授耗时十年研究成果《这样教写作不难——基于小学生心理特点的写作教学序列与模式》中系列教学模式之一。其教学目标具体,评价标准明确,教学步骤清晰,教学策略可操作性强,是续写与仿写的高度融合,运用于实践,写不难,教简易。《小马过河》是统编本小学语文二年级下册的童话体裁课文,深蕴哲理,情节生动,童趣盎然,运用本模式引导学生写话,既可深化学生对故事蕴含哲理的感受和体验,
美国是世界上现代化水平较高的国家,在政治、经济、文化等多领域中处于世界前列,对美国的发展历程进行解析是明确美国现代化历程、现代化特征的有效途径。刘英的《书写现代性:美国文学中的地理与空问》是有关美国文学与现代化进程的论著。该书以文化地理学理论为基础,探讨了美国二战前后文学发展的历程,旨在通过找到美国文学和国家、地域、地方等空間尺度上的关联,明确乡镇空间、城市空间、国家空间、优选空间等空间领域的文学
摘要:该文提出了使用常用系统分区备份软件实现RAID服务器的系统分区备份的思路,并给出了其中一种思路的详细步骤。  关键词:RAID;服务器;系统分区;备份  中图分类号:TP368文献标识码:A文章编号:1009-3044(2008)32-1088-01  Backup Method of Syetem Partition in the Server with RAID Controller  
《普通高中语文课程标准(2017年版)》改变了长期以来用识字与写字、阅读、写作、口语交际、综合性学习五大领域来组织课程内容的方式,架构了以核心素养为纲,学生的语文实践为主线,以任务群为项目化学习载体的课程组织和实施方式。高中课标反映了先进的教育思想和教育理念,特别关注信息化环境下的教学改革,关注学生个性化、多样化的学习和发展需求,提出“教学应该更加关注育人的目的,更加注重培养学生的核心素养,更加强
摘要:今年二月份Adobe公司推出了AIR 1.0版本,AIR对大多数人来说,都非常的陌生。该文简要的概述了什么是AIR,AIR的优点,如何来构建AIR程序等问题。  关键词:AIR;Adobe;程序   中图分类号:TP317文献标识码:A文章编号:1009-3044(2008)29-0386-01  Brife Analysis of AIR Technology  GUO Fu-san  (
书名:博物馆教育新视阈  作者:杨丹丹、阎宏斌  出版社:文物出版社  出版时间:2009年  ISBN:9787501027125  定价:35元  博物馆即博览万物之所,是展示人类文明进程的恢宏殿堂,是文化传承的重要载体。现在,博物馆的功能也越来越丰富,已然实现了从收藏研究到教育服务的转变,尤其是对于青少年的知识普及、兴趣培养和思想启蒙发挥着重要的作用。在我国,博物馆教育与学校教育的配合可谓由
摘要:主要探讨了在基于MapInfod的二次开发应用系统中,采用OLE自动化以及与客户/服务器开发工具PowerBuilder系统集成开发的基本方法和集成开发中的一些关键技术的实现方法。  关键词:PowerBuilder;MapInfo;MapBasic;OLE自动化  中图分类号:TP311文献标识码:A文章编号:1009-3044(2008)34-1564-03  PowerBuilder