在vb中使用Iphlpapi.dll获取网络信息(上)

※==================================================================
※本连载文章说明:
※1、连载首发于《软件报》(http://www.sweek.com)2006年21期(2006年5月22日);
※2、此次网上连载采用的是原稿件结构,内容与《软件报》发表略有不同;
※3、谢绝除《软件报》及其相关刊物之外的传统媒体部分或全部转载;
※4、谢绝任何收费媒体、网络转载;
※5、原作者:uruseibest ,blog:http://blog.csdn.net/uruseibest
※6、如有其它疑问,请联系作者;
※7、如有转载,必须连同本说明一并发表,否则将追究转载者责任。
※======================================================================

 

第一章 前言

第二章 主要函数
第一节 获取本机网络适配器的信息 GetAdaptersInfo
第二节 获取MIB-II 接口表 GetIfTable
第三节 获取本机TCP 信息列表 GetTcpStatistics
第四节 获取当前TCP连接情况 GetTcpTable
第五节 获取本机UDP信息列表 GetUdpStatistics
第六节 获取当前UDP连接情况 GetUdpTable
第七节 获取本机网间控制报文协议信息 GetIcmpStatistics
第八节 获取本机网络参数 GetNetworkParams
第九节 获取网卡–IP地址映射表 GetIpAddrTable
第十节 获取本机已探测的IP – 物理地址映射表 GetIpNetTable
第十一节 获取当前计算机的IP信息 GetIpStatistics
第十二节 获得本机系统网络接口适配器的列表 GetInterfaceInfo
第十三节 获得目的地IP(只能是所在局域网中的IP)对应的物理地址 SendARP
第十四节 返回本机网络接口数量 GetNumberOfInterfaces
第十五节 设置本机默认的生存时间(time-to-live:TTL)值 SetIpTTL
第十六节 获取本机IP 路由表 GetIpForwardTable
第十七节 设置TCP连接状态 SetTcpEntry
第十八节 在本地电脑的地址解析协议(ARP :Address Resolution Protocol)表中创建和删除一个ARP CreateIpNetEntry
第十九节 Ping一个IP地址 IcmpCreateFile...
第二十节 测定到指定目的地往返时间和跳跃数
第二十一节 增加和删除一个IP地址


第三章 IPHLPAPI 的其他函数
第一节 IPHLPAPI 的其它函数
第二节 从C原型到Vb声明


第四章 错误处理及其它
第一节 错误处理
第二节 一个重要函数
第三节 实例一:网络数据流量图
第四节 实例二:探测到某个IP地址经过的路由列表

第五章 结束语

第一章 前言
Windows 98以上的操作系统在系统目录下都带有iphlpapi.dll这个动态链接库文件,它可以帮助程序员方便地获取计算机网络信息。对于C程序员来说,只要有iphlpapi的头文件,调用iphlpapi.dll是很简单的事,但是对于Vb程序员则是比较困难的问题。本文将就Vb中调用iphlpapi.dll来介绍iphlpapi的使用。

第二章 IPHLPAPI 的主要函数
本章将根据iphlpapi.dll提供函数的功能来分别讲解iphlpapi.dll的主要函数。编程时,我们可以调用这些函数迅速获得本机大部分网络信息。

第一节 获取本机网络适配器的信息
1、函数:
Private Declare Function GetAdaptersInfo Lib "iphlpapi.dll" ( IpAdapterInfo As Any, pOutBufLen As Long) As Long
参数说明:
pAdapterInfo:[输出] 指向一个IP_ADAPTER_INFO类型的连接表;
pOutBufLen:[输入] 指定pAdapterInfo参数的大小,如果指定大小不足,GetAdaptersInfo将此参数置为所需大小, 并返回一个ERROR_BUFFER_OVERFLOW错误代码。
返回值:成功,返回0;失败,返回错误代码。
备注:此函数不能获得回环(Loopback)适配器的信息
2、使用到的类型:
①IP_ADAPTER_INFO类型:包含本机网络适配器信息。
Type IP_ADAPTER_INFO
Next As Long                ‘在适配器列表中指向下一个适配器
ComboIndex As Long    ‘保留未用
AdapterName As String * MAX_ADAPTER_NAME_LENGTH                ‘适配器名
Description As String * MAX_ADAPTER_DESCRIPTION_LENGTH      ‘对网卡的描述,实际上好象是驱动程序的名字
AddressLength As Long        ‘适配器物理地址的长度
Address(MAX_ADAPTER_ADDRESS_LENGTH - 1) As Byte          ‘物理地址,每个字节存放一个十六进制的数值
Index As Long                     ‘适配器索引号
Type As Long               ‘适配器类型,包含以下类型的适配器(见下表):
常量名称 值 说明
MIB_IF_TYPE_ETHERNET 6 以太网适配器
MIB_IF_TYPE_TOKENRING 9 令牌环适配器
MIB_IF_TYPE_FDDI 15 光纤接口适配器
MIB_IF_TYPE_PPP  23 点到点协议适配器
MIB_IF_TYPE_LOOPBACK 24 回环(Loopback)适配器
MIB_IF_TYPE_SLIP 28 串行适配器(Serial Line Interface Protocol)
MIB_IF_TYPE_OTHER 其他值 其他类型的适配器

DhcpEnabled As Long           ‘适配器是否启用了动态主机配置协议(DHCP)
CurrentIpAddress As Long    ‘保留(当前使用的IP地址?)
IpAddressList As IP_ADDR_STRING        ‘绑定到此适配器的IP地址链表
GatewayList As IP_ADDR_STRING          ‘默认网关地址链表
DhcpServer As IP_ADDR_STRING         ‘DHCP服务器地址,DhcpEnabled=TRUE时有效
HaveWins As Byte         ‘是否启用WINS(Windows Internet Name Service)
PrimaryWinsServer As IP_ADDR_STRING              ‘主WINS地址
SecondaryWinsServer As IP_ADDR_STRING           ‘辅WINS地址
LeaseObtained As Long  ‘向DHCP服务器租用IP地址的时间,DhcpEnabled=TRUE时有效
LeaseExpires As Long    ‘向DHCP服务器租用IP地址到期时间,DhcpEnabled=TRUE时有效
End Type

② IP_ADDR_STRING描述IP 地址链表的节点。
Type IP_ADDR_STRING
Next As Long         ‘指向列表中下一个IP_ADDR_STRING类型。为空,则是最后一个地址
IpAddress As String * 16      ‘点式十进制字串表示Ip地址
IpMask As String * 16          ‘子网掩码
Context As Long                  ‘网络IP地址标识,符合AddIPAddress和DeleteIPAddress函数中的网络接口关联参数。
End Type

3、使用到的常量:
Const MAX_ADAPTER_NAME_LENGTH = 260
Const MAX_ADAPTER_ADDRESS_LENGTH = 8
Const MAX_ADAPTER_DESCRIPTION_LENGTH = 132

4、主要代码分析:
①调用函数GetAdaptersInfo,以及在调用中应该注意的问题:对函数GetAdaptersInfo进行两次调用,第一次调用获得参数pOutBufLen的实际大小;第二次调用获取IpAdapterInfo的数据。代码如下:
pOutBufLen = 0
error = GetAdaptersInfo(ByVal 0&, pOutBufLen)
ReDim AdapterInfoBuffer(pOutBufLen - 1)
error = GetAdaptersInfo(AdapterInfoBuffer(0), pOutBufLen)
② IpAdapterInfo中可能包含多个IP_ADAPTER_INFO类型,因此下一步使用copymemory函数将数据拷贝到IP_ADAPTER_INFO类型:
CopyMemory AdapterInfo, AdapterInfoBuffer(0), pOutBufLen
③获得了首个IP_ADAPTER_INFO类型后,根据IP_ADAPTER_INFO类型中的Next成员并调用循环语句(Do…Loop Until)来获得所有IP_ADAPTER_INFO类型:
Do
pAdapt = AdapterInfo.Next
If pAdapt <> 0 Then
CopyMemory AdapterInfo, ByVal pAdapt, AdapterInfoSize
End If
Loop Until pAdapt = 0
④由每次获得的IP_ADAPTER_INFO类型来获取网络适配器物理地址:
    PhysicalAddress = ""
    For i = 0 To AdapterInfo.AddressLength - 1
        PhysicalAddress = PhysicalAddress & Hex(AdapterInfo.Address(i))
        If i < AdapterInfo.AddressLength - 1 Then
            PhysicalAddress = PhysicalAddress & "-"
        End If
Next
⑤对于属于IP_ADDR_STRING类型的IpAddressList、GatewayList、DhcpServer、PrimaryWinsServer、SecondaryWinsServer,同样要注意IP_ADDR_STRING中Next成员的使用:
    Do
        CopyMemory IP_ADDR_STRING, AdapterInfo.IpAddressList, LenB(IP_ADDR_STRING)
        Print "IP Address: " & IP_ADDR_STRING.IpAddress
        Print "Subnet Mask: " & IP_ADDR_STRING.IpMask
        pAddrStr = IP_ADDR_STRING.Next
        If pAddrStr <> 0 Then
            CopyMemory IP_ADDR_STRING.IpAddressList, ByVal pAddrStr, _
                   LenB(IP_ADDR_STRING.IpAddressList)
        End If
    Loop Until pAddrStr = 0
5、运行时截图:

第二节 获取MIB-II 接口表
1、函数:
Private Declare Function GetIfTable Lib "iphlpapi.dll" (ByRef pIfTable As MIB_IFTABLE, ByRef pdwSize As Long, ByVal bOrder As Long) As Long
参数说明:
pIfTable:[输入]成功的话指向一个MIB_IFTABLE类型的缓冲区。
PdwSize:[输入,输出]指定pIfTable参数所占缓冲区的大小,如果缓冲区不是足够大返回接口表,函数设置这个参数等于所必须的缓冲区大小。
bOrder:[输入]指定返回的接口表是否按接口序号按上升顺序排列。如果参数为TRUE那么按上升顺序排列。
返回值:成功,返回0;失败,返回错误代码。

2、使用到的类型:
①MIB_IFTABLE  包含接口表
Private Type MIB_IFTABLE
    dwNumEntries As Long            '当前网络接口的总数
    MIB_Table(9) As MIB_IFROW         '指向一个包含MIB_IFROW类型的指针
End Type
②MIB_IFROW 保存接口信息
Private Type MIB_IFROW
    wszName(0 To 511) As Byte '接口名称的Unicode字符串,必须为512字节
    dwIndex As Long         '接口编号
    dwType As Long          '接口类型,参看IP_ADAPTER_INFO类型的Type成员
    dwMtu As Long           '最大传输单元
    dwSpeed As Long          '接口速度(字节)
    dwPhysAddrLen As Long   '由bPhysAddr获得的物理地址有效长度
    bPhysAddr(0 To 7) As Byte '物理地址
    dwAdminStatus As Long     '接口管理状态
dwOperStatus As Long            '操作状态,以下值之一:

常量名称  值  说明
MIB_IF_OPER_STATUS_NON_OPERATIONAL 0  网络适配器被禁止,例如:地址冲突
MIB_IF_OPER_STATUS_UNREACHABLE 1  没有连接
MIB_IF_OPER_STATUS_DISCONNECTED 2  局域网:电缆未连接;广域网:无载波信号
MIB_IF_OPER_STATUS_CONNECTING 3  广域网适配器连接中
MIB_IF_OPER_STATUS_CONNECTED 4  广域网适配器连接上远程对等点
MIB_IF_OPER_STATUS_OPERATIONAL 5  局域网适配器默认状态

    dwLastChange As Long    '操作状态最后改变的时间
    dwInOctets As Long        '总共收到(字节)
    dwInUcastPkts As Long     '总共收到(unicast包)
    dwInNUcastPkts As Long    '总共收到(non-unicast包),包括广播包和多点传送包
    dwInDiscards As Long     '收到后丢弃包总数(即使没有错误)
    dwInErrors As Long        '收到出错包总数
    dwInUnknownProtos As Long   '收到后因协议不明而丢弃的包总数
    dwOutOctets As Long       '总共发送(字节)
    dwOutUcastPkts As Long    '总共发送(unicast包)
    dwOutNUcastPkts As Long '总共发送(non-unicast包),包括广播包和多点传送包
    dwOutDiscards As Long     '发送丢弃包总数(即使没有错误)
    dwOutErrors As Long       '发送出错包总数
    dwOutQLen As Long      '发送队列长度
    dwDescrLen As Long       ' bDescr部分有效长度
    bDescr(0 To 255) As Byte  '接口描述
End Type

3、使用到的常量:

4、主要代码分析:
①分配足够大的缓存空间,然后直接调用GetIfTable获得接口信息:
Dim ifT As MIB_IFTABLE
LenIfT = Len(ifT)
RValue = GetIfTable(ifT, LenIfT, True)
②由ifT.dwNumEntries获得接口数量,然后用for…next循环获取每个接口信息:
For i = 0 To ifT.dwNumEntries - 1
Print "接口编号:" & ifT.MIB_Table(i).dwIndex
Print "接口速度:" & ifT.MIB_Table(i).dwSpeed
Next
③物理地址的获得:
    PhysAddr = Right("00" & Hex(ifT.MIB_Table(i).bPhysAddr(0)), 2)
    For j = 1 To 5
        PhysAddr = PhysAddr & "-" & Right("00" & Hex(ifT.MIB_Table(i).bPhysAddr(j)), 2)
    Next
Print "物理地址:" & PhysAddr

5、运行时截图:
第三节 获取本机TCP 信息列表
1、函数:
Private Declare Function GetTcpStatistics Lib "iphlpapi.dll" (ByRef pTcpStats As MIB_TCPSTATS) As Long
参数说明:
pStats :[输出]指向一个接收本机TCP统计表的MIB_TCPSTATS类型
返回值:成功,返回0;失败,返回错误代码。

2、使用到的类型:

①MIB_TCPSTATS 包含本机上正运行的TCP协议的统计表
Type MIB_TCPSTATS
dwRtoAlgorithm As Long      ‘指定重传输(RTO:retransmission time-out)算法
    dwRtoMin As Long              ‘重传输超时的最小值,毫秒
    dwRtoMax As Long              ‘重传输超时的最大值,毫秒
    dwMaxConn As Long           ‘连接最大数目,如果为-1,则连接的最大数目是可变的
    dwActiveOpens As Long       ‘主动连接数目,即客户端正向服务器进行连接数目
    dwPassiveOpens As Long     ‘被动连接数目,即服务器监听连接客户端请求数目
    dwAttemptFails As Long       ‘尝试连接失败的次数
    dwEstabResets As Long        ‘对已建立的连接实行重设的次数
    dwCurrEstab As Long           ‘目前已建立的连接
    dwInSegs As Long               ‘收到分段数据报的数目
    dwOutSegs As Long             ‘传输的分段数据报数目,不包括转发的数据包
    dwRetransSegs As Long              ‘转发的分段数据报数目
    dwInErrs As Long                ‘收到错误的数目
    dwOutRsts As Long             ‘重设标志设定后传输分段数据报数目
    dwNumConns As Long         ‘累计连接的总数
End Type

3、使用到的常量:

4、主要代码分析:
① 定义一个MIB_TCPSTATS类型变量,然后直接调用GetTcpStatistics:
       Dim mTcpS As MIB_TCPSTATS
RValue = GetTcpStatistics(mTcpS)

5、运行时截图:

第四节 获取当前TCP连接情况
1、函数:
Private Declare Function GetTcpTable Lib "iphlpapi.dll" (ByRef pTcpTable As MIB_TCPTABLE, ByRef pdwSize As Long, ByVal bOrder As Long) As Long
参数说明:
pTcpTable:[输入]指向包含了MIB_TCPTABLE类型的TCP 连接表。
pdwSize:[输入,输出]指向pTcpTable参数的缓冲区大小,如果分配的缓冲不够,那么就等于最小需要缓冲。
bOrder:[输入]指定连接表是否按照类型排列。TRUE,那么就按以下类型顺序排列:Local IP address,Local port,Remote IP address,Remote port。
返回值:成功,返回0;失败,返回错误代码。

2、使用到的类型:
①MIB_TCPTABLE 类型包含Tcp连接表。
Type MIB_TCPTABLE
dwNum_Of_Entries As Long               ‘当前包含MIB_TCPROW类型的总数
TCP_Table() As MIB_TCPROW        ‘指向包含MIB_TCPROW类型的指针
End Type
备注:实际使用中可以定义:TCP_Table(120) As MIB_TCPROW       ' 预留足够缓存
②MIB_TCPROW 类型包含了TCP连接信息。
Type MIB_TCPROW
dwState As Long                 ' TCP连接状态,为以下值之一:
常量名称  值  说明
MIB_TCP_STATE_CLOSED 1  关闭
MIB_TCP_STATE_LISTEN 2  正在监听
MIB_TCP_STATE_SYN_SENT 3  同步发送
MIB_TCP_STATE_SYN_RCVD 4  同步接收
MIB_TCP_STATE_ESTAB 5  已建立
MIB_TCP_STATE_FIN_WAIT1 6  FINWAIT 1
MIB_TCP_STATE_FIN_WAIT2 7  FINWAIT 2
MIB_TCP_STATE_CLOSE_WAIT 8  关闭等待
MIB_TCP_STATE_CLOSING 9  正在关闭
MIB_TCP_STATE_LAST_ACK 10  最后一次确认
MIB_TCP_STATE_TIME_WAIT 11  时间等待
MIB_TCP_STATE_DELETE_TCB 12  删除连接

dwLocalAddr As Long         '本地IP
dwLocalPort As Long          '本地端口
dwRemoteAddr As Long      '远程机器IP
dwRemotePort As Long       '远程机器端口
End Type

3、使用到的常量:

4、主要代码分析:
①定义一个MIB_TCPTABLE类型的变量,因为我们在定义MIB_TCPTABLE类型的时候预留了足够的缓存( TCP_Table(120) As MIB_TCPROW ),因此获得定义变量的大小后直接调用GetTcpTable,但是要注意的是,实际获得的TCP连接的总数应为dwNum_Of_Entries的值,一般小于我们的定义(120):
Dim mtcp As MIB_TCPTABLE
mtcplen = Len(mtcp)
rvalue = GetTcpTable(mtcp, mtcplen, True)
②使用For…Next循环遍历各个Tcp连接的信息:
For i = 0 To mtcp.dwNum_Of_Entries - 1
Print  mtcp.TCP_Table(i).dwLocalAddr & "->" & mtcp.TCP_Table(i).dwRemoteAddr
Next
③因为MIB_TCPROW 类型中dwLocalAddr、dwRemoteAddr均为一长整型数,因此要通过转换来获得IP地址:
Dim Ip_Buf(1 To 4) As Byte
CopyMemory Ip_Buf(1), dwLocalAddr, 4
GetIp = CStr(Ip_Buf(1)) + "." + CStr(Ip_Buf(2)) + "." + CStr(Ip_Buf(3)) + "." + CStr(Ip_Buf(4))
④因为MIB_TCPROW 类型中dwLocalPort、dwRemotePort均为一长整型数,因此要通过转换来获得端口:
GetPort = dwLocalPort/ 256 + (dwLocalPort Mod 256) * 256

5、运行时截图:

第五节 获取本机UDP信息列表
1、函数:
Private Declare Function GetUdpStatistics Lib "iphlpapi.dll" (pStats As MIB_UDPSTATS) As Long
参数说明:
pStats:[输出]指向一个接收到本机UDP统计表的MIB_UDPSTATS类型
返回值:成功,返回0;失败,返回错误代码。

2、使用到的类型:
①MIB_UDPSTATS 包含UDP (User Datagram Protocol) 运行信息
Type MIB_UDPSTATS
    dwInDatagrams As Long   '已收到数据报数目
    dwNoPorts As Long       '因为端口号有误而丢弃的数据报数目
    dwInErrors As Long        '已收到多少错误数据报,不包括dwNoPorts中统计的数目
    dwOutDatagrams As Long  '已传输数据报数目
    dwNumAddrs As Long     'UDP监听者表中接口数目
End Type

3、使用到的常量:

4、主要代码分析:
①定义一个MIB_UDPSTATS类型的变量,然后直接使用GetUdpStatistics函数即可:
Dim Mudp As MIB_UDPSTATS
r = GetUdpStatistics(Mudp)

5、运行时截图:

第六节 获取当前UDP连接情况
1、函数:
Private Declare Function GetUdpTable Lib "iphlpapi.dll" (ByRef pTcpTable As MIB_UDPTABLE, ByRef pdwSize As Long, ByVal bOrder As Long) As Long
参数说明:
pUdpTable:[输出]指向一个缓存作为MIB_UDPTABLE类型用来接收UDP监听表。
pdwSize:[输入或输出]输入,指定pUdpTable参数所占缓存大小;输出,如果指定的缓存大小不足,将设置为所须的大小。
bOrder:[输入]指定返回的表是否按分类排列。如果为TRUE,按以下分类排列:1、IP地址;2、端口。
返回值:成功,返回0;失败,返回错误代码。

2、使用到的类型:
①MIB_UDPTABLE 包含MIB_UDPROW类型
Type MIB_UDPTABLE
    dwNum_Of_Entries As Long                 '当前 UDP连接的总数
    UDP_Table() As MIB_UDPROW              '指向包含MIB_UDPROW类型的指针
End Type
备注:实际使用中可以定义:UDP_Table(120) As MIB_UDPROW      ' 预留足够缓存

②MIB_UDPROW包含发送和接收UDP数据包的地址信息。它的格式如下:
Type MIB_UDPROW
    dwLocalAddr As Long         '本地IP
    dwLocalPort As Long         '本地端口
End Type

3、使用到的常量:

4、主要代码分析:
①定义一个MIB_TCPTABLE类型的变量,因为我们在定义MIB_TCPTABLE类型的时候预留了足够的缓存( TCP_Table(120) As MIB_TCPROW ),因此获得定义变量的大小后直接调用GetTcpTable。但是要注意的是,实际获得的UDP连接的总数应为dwNum_Of_Entries的值,一般小于我们的定义(120):
Dim Mudp As MIB_UDPTABLE
mudplen = Len(Mudp)
rvalue = GetUdpTable(Mudp, mudplen, True)
②使用For…Next循环遍历各个Tcp连接的信息:
For i = 0 To Mudp.dwNum_Of_Entries - 1
           Print  Mudp.UDP_Table(i).dwLocalAddr & ":" & Mudp.UDP_Table(i).dwLocalPort
Next
③因为MIB_UDPTABLE 类型中dwLocalAddr为一长整型数,因此要通过转换来获得IP地址:
Dim Ip_Buf(1 To 4) As Byte
CopyMemory Ip_Buf(1), dwLocalAddr, 4
GetIp = CStr(Ip_Buf(1)) + "." + CStr(Ip_Buf(2)) + "." + CStr(Ip_Buf(3)) + "." + CStr(Ip_Buf(4))
④因为MIB_UDPTABLE类型中dwLocalPort为一长整型数,因此要通过转换来获得端口:
GetPort = dwLocalPort/ 256 + (dwLocalPort Mod 256) * 256

5、运行时截图:

第七节 获取本机网间控制报文协议(ICMP:Internet Control Message Protocol)信息
1、函数:
Private Declare Function GetIcmpStatistics Lib "iphlpapi.dll" (pStats As MIB_ICMP) As Long
参数说明:
pStats:[输出] 指向一个本机收到ICMP 统计表的MIB_ICMP类型。
返回值:成功,返回0;失败,返回错误代码。

2、使用到的类型:
①MIB_ICMP 为特殊适配器包含网间控制报文协议(ICMP:Internet Control Message Protocol)统计表。
Public Type MIB_ICMP
    stats As MIBICMPINFO    '指定MIBICMPINFO类型包含了电脑ICMP统计信息表
End Type
②MIBICMPINFO通过MIBICMPSTATS结构存储的接收或发出的ICMP信息。
Public Type MIBICMPINFO
  icmpInStats As MIBICMPSTATS   '指向MIBICMPSTATS类型,包含接收数据
  icmpOutStats As MIBICMPSTATS '指向MIBICMPSTATS类型,包含发出数据
End Type

③MIBICMPSTATS包含ICMP (Internet Control Message Protocol)接收或发出的统计信息。

Public Type MIBICMPSTATS

    dwMsgs As Long          '已收发多少消息

    dwErrors As Long          '已收发多少错误

    dwDestUnreachs As Long    '已收发多少"目标不可抵达"消息

    dwTimeExcds As Long            '已收发多少生存期已过消息

    dwParmProbs As Long            '已收发多少表明数据报内有错误IP信息的消息

    dwSrcQuenchs As Long           '已收发多少源结束消息

    dwRedirects As Long        '已收发多少重定向消息

    dwEchos As Long                '已收发多少ICMP响应请求

    dwEchoReps As Long             '已收发多少ICMP响应应答

    dwTimestamps As Long    '已收发多少时间戳请求

    dwTimestampReps As Long        '已收发多少时间戳响应

    dwAddrMasks As Long      '已收发多少地址掩码

    dwAddrMaskReps As Long '已收发多少地址掩码响应

End Type

 

3、使用到的常量:

 

4、主要代码分析:

①定义一个MIB_ICMP类型的变量,然后直接调用GetIcmpStatistics:

Dim Micmp As MIB_ICMP

r = GetIcmpStatistics(Micmp)

②使用Micmp.stats.icmpInStats成员获取收到的数据信息;使用Micmp.stats.icmpOutStats成员获取发送的数据信息。

 

5、运行时截图:

第八节 获取本机网络参数

1、函数:

Private Declare Function GetNetworkParams Lib "IPHlpApi.dll" (FixedInfo As Any, pOutBufLen As Long) As Long

参数说明:

pFixedInfo:[输出]指向一个接收本机网络参数的数据块。

pOutBufLen:[输入,输出]指向一个ULONG变量,改变量指定了FixedInfo参数的大小。如果指定的大小不够大,将设置为须要的大小并返回ERROR_BUFFER_OVERFLOW错误。

返回值:成功,返回0;失败,返回错误代码。

 

2、使用到的类型:

①IP_ADDR_STRING描述IP 地址链表的节点。

见 第二章  第一节  2  ②

②FIXED_INFO包含电脑网络参数信息

Type FIXED_INFO

HostName As String * MAX_HOSTNAME_LEN ‘本机名

DomainName As String * MAX_DOMAIN_NAME_LEN    ‘本机DNS域

CurrentDnsServer As Long           ‘保留,使用DnsServerList获取DNS服务器的IP地址

DnsServerList As IP_ADDR_STRING ‘本机采用的DNS服务器链表

NodeType As Long        ‘节点类型,以下值:

1         BROADCAST_NODETYPE              IP广播,b节点NetBIOS名字解析法

2         PEER_TO_PEER_NODETYPE   点到点通信,p节点名字解析

4         MIXED_NODETYPE                         Mixed,m节点NetBIOS名字解析法

8         HYBRID_NODETYPE                      Hybrid,h节点NetBIOS名字解析法

Else                                                             未知节点类型

ScopeId  As String * MAX_SCOPE_ID_LEN    ‘DHCP范围名字

EnableRouting As Long  ‘本机能否路由

EnableProxy As Long     ‘本机能否作为地址解析协议(ARP)代理

EnableDns As Long       ‘本机能否DNS查询

End Type

备注:此类型在vb中和c中的定义有所不同,详情请参看MSDN。

 

3、使用到的常量:

Const MAX_HOSTNAME_LEN = 132

Const MAX_DOMAIN_NAME_LEN = 132

Const MAX_SCOPE_ID_LEN = 260

 

4、主要代码分析:

①由于IP_ADDR_STRING的实际大小未知,我们不能直接获取其大小,所以首先对函数GetNetworkParams进行两次调用,第一次调用获得参数pOutBufLen的实际大小;第二次调用获取FixedInfoBuffer(0)的数据。代码如下:

       Dim FixedInfoBuffer() As Byte

FixedInfoSize = 0

rvalue = GetNetworkParams(ByVal 0, FixedInfoSize)

ReDim FixedInfoBuffer(FixedInfoSize - 1)

rvalue = GetNetworkParams(FixedInfoBuffer(0), FixedInfoSize)

②使用copymemory函数将数据拷贝到FixedInfo中,然后就可以使用FIXED_INFO结构了:

CopyMemory FixedInfo, FixedInfoBuffer(0), FixedInfoSize

Print "Host Name", FixedInfo.HostName

③采用Do循环来获取所有DNS服务器地址:

Print "DnsServer IP", FixedInfo.DnsServerList.IpAddress

pAddrStr = FixedInfo.DnsServerList.Next

Do While pAddrStr <> 0

    CopyMemory IPAS, ByVal pAddrStr, LenB(IPAS)

    Print "DNSServer IP", IPAS.IpAddress

    pAddrStr = IPAS.Next

Loop

 

5、运行时截图:

第九节 获取网卡–IP地址映射表

1、函数:

Private Declare Function GetIpAddrTable Lib "iphlpapi.dll" (pIpAddrTable As MIB_IPADDRTABLE, pdwSize As Long, bOrder As Long) As Long

参数说明:

pIpAddrTable:[输出] 指向一个接收网卡–IP地址映射表的 MIB_IPADDRTABLE类型的指针。

pdwSize:[输入,输出]输入,指定pIpAddrTable 参数指向缓存的大小;输出,如果指定的缓存大小不够大,将设置此参数为必须的大小。

bOrder:[输入] 指定返回的映射表是否按照IP地址排列。TRUE,按顺序排列。

返回值:成功,返回0;失败,返回错误代码。

 

2、使用到的类型:

①MIB_IPADDRTABLE 包含IP地址入口表
Type MIB_IPADDRTABLE

    dwNumEntries As Long              '表明table字段数组中有多少MIB_IPADDROW条目

    table() As MIB_IPADDRROW      '指向MIB_IPADDRROW类型

End Type

②MIB_IPADDRROW 指定特殊IP地址的信息
Type MIB_IPADDRROW

    dwAddr As Long          '接口的IP地址

    dwIndex As Long     '与IP地址关联的接口之索引

    dwMask As Long         '子网掩码

    dwBCastAddr As Long   ’广播地址

    dwReasmSize As Long '已收到的数据报重装后的最大长度

    unused1 As Integer      '未使用

    unused2 As Integer      '未使用

End Type

 

3、使用到的常量:

 

4、主要代码分析:

①定义一个MIB_IPADDRTABLE类型的变量并获取此变量的大小,然后直接调用GetTcpTable:

Dim IpAddrTable As MIB_IPADDRTABLE

dwsize = Len(IpAddrTable)

r = GetIpAddrTable(IpAddrTable, dwsize, order)

②调用For…Next循环,获取每个网卡–IP地址映射的信息:

For i = 0 To IpAddrTable.dwNumEntries - 1

    Print "dwAddr", IpAddrTable.table(i).dwAddr

Next

③将长整型格式的ip地址转换为标准IP地址格式("xxx.xxx.xxx.xxx"格式):

Private Function inversaip(IPAddrLng As Long) As String

Dim sos As String

Dim i As Long

Dim IPadd As String

 

IPadd = Right("00000000" & Hex(IPAddrLng), 8)

sos = ""

For i = 1 To Len(IPadd) Step 2

    sos = CInt("&h" & Mid(IPadd, i, 2)) & "." & sos

Next i

inversaip = Mid(sos, 1, Len(sos) - 1)

End Function

 

5、运行时截图:

 

第十节 获取本机已探测的IP – 物理地址映射表

1、函数:

Private Declare Function GetIpNetTable Lib "iphlpapi.dll" (pIpNetTable As MIB_IPNETTABLE, pdwSize As Long, bOrder As Long) As Long

参数说明:

pIpNetTable:[输出]指向一个返回IP至物理地址映射作为MIB_IPNETTABLE类型的缓存。

pdwSize:[输入,输出] 输入,指定pIpNetTable参数指向缓存的大小;输出,如果指定的缓存大小不够大,将设置此参数为必须的大小。

bOrder:[输入] 指定返回的映射表是否按照IP地址排列。TRUE,按序排列。

返回值:成功,返回0;失败,返回错误代码。

 

2、使用到的类型:

①MIB_IPNETTABLE 包含地址解析协议(ARP :Address Resolution Protocol)接口入口表。

Type MIB_IPNETTABLE

       DwNumEntries As Long                            ‘当前包含MIB_IPNETROW类型的总数

       MIB_Table() As MIB_IPNETROW      ‘指向一个包含MIB_IPNETROW类型的指针

End Type

 

②MIB_IPNETROW 包含地址解析协议(ARP :Address Resolution Protocol)接口信息:

Type MIB_IPNETROW

    dwIndex As Long                '指定适配器的索引

    dwPhysAddrLen As Long    'bPhysAddrs字段内包含的物理接口的长度(字节),通常为6

    bPhysAddr(MAXLEN_PHYSADDR) As Byte      '字节数组,包含适配器的物理地址

    dwAddr As Long                       'IP地址

dwType As Long                       'ARP接口的类型,以下值之一:

常量名称  值  说明
MIB_IPNET_TYPE_OTHER 1 其他条目
MIB_IPNET_TYPE_INVALID 2 无效条目
MIB_IPNET_TYPE_DYNAMIC 3 动态条目
MIB_IPNET_TYPE_STATIC 4 静态条目

 


End Type

 

3、使用到的常量:

Const MAXLEN_PHYSADDR = 7

 

4、主要代码分析:

①定义一个MIB_IPNETTABLE类型的变量并获取此变量的大小,然后直接调用GetIpNetTable:

Dim ipNett As MIB_IPNETTABLE

dwsize = Len(ipNett)

r = GetIpNetTable(ipNett, dwsize, bOrder)

②调用For…Next循环,获取每个网卡–IP地址映射的信息:

For i = 0 To ipNett.dwNumEntries - 1

    Print "类型", ipNett.MIB_Table(i).dwType

Next

③在②中循环获取物理地址:

    ByteToS = ""

    ByteToS = Right("00" & Hex(ipNett.MIB_Table(i).bPhysAddr(0)), 2)

    For j = 1 To ipNett.MIB_Table(i).dwPhysAddrLen - 1 Step 1

        ByteToS = ByteToS & "-" & Right("00" & Hex(ipNett.MIB_Table(i).bPhysAddr(j)), 2)

    Next

④将长整型格式的ip地址转换为标准IP地址格式("xxx.xxx.xxx.xxx"格式):

Private Function inversaip(IPAddrLng As Long) As String

       ‘同 十、 4、 ③

End Function

 

5、运行时截图:

第十一节 获取当前计算机的IP信息

1、函数:

Private Declare Function GetIpStatistics Lib "iphlpapi.dll" (pStats As MIB_IPSTATS) As Long

参数说明:

pStats:[输出] 指向一个包含IP信息的MIB_IPSTATS类型。

返回值:成功,返回0;失败,返回错误代码。

 

2、使用到的类型:

①MIB_IPSTATS 存储于电脑的IP协议运行信息。
Type MIB_IPSTATS

    dwForwarding As Long        '启用或者禁止转发IP包(IP forwarding)

    dwDefaultTTL As Long        '指定默认初始化的生存时间(TTL)的值

    dwInReceives As Long     '已收到数据包数目

    dwInHdrErrors As Long    '已收到报头有误的数据包数目

    dwInAddrErrors As Long   '已收到地址有误的数据包数目

    dwForwDatagrams As Long  '已转发数据报数目

    dwInUnknownProtos As Long      '已收到协议不明的数据报数目

    dwInDiscards As Long         '已收到多少已丢弃的数据报

    dwInDelivers As Long       '已收到多少已投递的数据报

    dwOutRequests As Long     '发送IP请求传输的数据报数目,不包括转发的数据包

    dwRoutingDiscards As Long '已丢弃的发送数据报数目

    dwOutDiscards As Long     '丢弃的传输数据报数目

    dwOutNoRoutes As Long     '没有路由目标IP地址而被丢弃的数据报数目

    dwReasmTimeout As Long   '分段数据报完全到达的最长时间,再此时间之外数据将被丢弃

    dwReasmReqds As Long     '需要重组的数据报数目

    dwReasmOks As Long       '已成功重组的数据报数目

    dwReasmFails As Long       '不能进行重组的数据报数目

    dwFragOks As Long        '已成功进行分段的数据报数目

    dwFragFails As Long      '不能进行分段的数据报数目,这些数据包将被丢弃

    dwFragCreates As Long      '可被分段的数据报数目

    dwNumIf As Long           '接口数目

    dwNumAddr As Long                '与此计算机关联的IP地址数目

    dwNumRoutes As Long      '路由表中可用的路由数目

End Type

 

3、使用到的常量:

 

4、主要代码分析:

①定义一个MIB_IPSTATS类型的变量,然后直接调用GetIpStatistics:

Dim MI As MIB_IPSTATS

r = GetIpStatistics(MI)

    Print "启用或者禁止转发IP包", MI.dwForwarding

 

5、运行时截图:

 

第十二节 获得本机系统网络接口适配器的列表

1、函数:

Private Declare Function GetInterfaceInfo Lib "iphlpapi.dll" (pIfTable As IP_INTERFACE_INFO, dwOutBufLen As Long) As Long

参数说明:

pIfTable: [输入] 指向一个指定一个包含了适配器列表的IP_INTERFACE_INFO类型的缓存。这个缓存应当由调用者分配。

dwOutBufLen:[输出] 指向一个DWORD变量。如果pIfTable参数为空,或者缓存不够大,这个参数返回必须的大小。

返回值:成功,返回0;失败,返回错误代码。

 

2、使用到的类型:

①IP_INTERFACE_INFO 包含本机系统网络适配器列表

Public Type IP_INTERFACE_INFO

    NumAdapters As Long             '适配器编号

    Adapter(1) As IP_ADAPTER_INDEX_MAP     'IP_ADAPTER_INDEX_MAP类型的数组

End Type

 

②IP_ADAPTER_INDEX_MAP 存储和适配器名称关联的接口序号

Public Type IP_ADAPTER_INDEX_MAP

    Index As Long       '和适配器关联的接口序号

Name As String * MAX_ADAPTER_NAME_LENGTH

'指向一个包含了适配器名称的Unicode字符串

End Type

 

3、使用到的常量:

Const MAX_ADAPTER_NAME_LENGTH = 260

 

4、主要代码分析:

①定义一个IP_INTERFACE_INFO类型的变量,对函数GetInterfaceInfo进行两次调用,第一次调用获得参数dwOutBufLen的实际大小;第二次调用获取pIfTable数据:

Dim pIfTable As IP_INTERFACE_INFO

r = GetInterfaceInfo(pIfTable, dwOutBufLen)

r = GetInterfaceInfo(pIfTable, dwOutBufLen)

②调用For…Next循环,获取每个网络接口适配器的信息,使用StrConv函数对获得的Unicode适配器名称进行转换:

For i = 0 To pIfTable.NumAdapters - 1

    Print pIfTable.Adapter(i).Index

    Print StrConv(pIfTable.Adapter(i).Name, vbFromUnicode)

Next

5、运行时截图:

第十三节 获得目的地IP(只能是所在局域网中的IP)对应的物理地址

1、函数:

①Private Declare Function SendARP Lib "iphlpapi.dll" (ByVal DestIP As Long, ByVal SrcIP As Long, pMacAddr As Long, PhyAddrLen As Long) As Long

参数说明:

DestIP:[输入]目的地IP地址。

SrcIP:[输入]发送地IP地址。可选参数,调用者可以指定此参数为0。

pMacAddr:[输出]指向一个ULONG变量数组(array)。数组前6个字节(bytes)接收由 DestIP指定的目的地IP物理地址。

PhyAddrLen:[输入,输出]输入,指定用户设置pMacAddr接收MAC地址的最大缓存大小,单位字节;输出,指定了写入pMacAddr的字节数量。

返回值:成功,返回0;失败,返回错误代码。

 

② inet_addr是Winsocket的函数而非”iphlpapi.dll”提供的函数,目的是将标准IP地址(”xxx.xxx.xxx.xxx”)的字符串转为电脑能识别的长整型的数据。

Private Declare Function inet_addr Lib "wsock32.dll" (ByVal cp As String) As Long

参数说明:

       cp:要转换的”xxx.xxx.xxx.xxx”形式的ip地址

 

2、使用到的类型:

 

3、使用到的常量:

 

4、主要代码分析:

①定义目标ip地址和源ip地址,源ip地址可以为0或inet_addr("127.0.0.1")或inet_addr(本机某个ip)。

Dim Dip As Long

Dim Sip As Long

Dip = inet_addr("xxx.xxx.xxx.xxx")

Sip = 0 'inet_addr("127.0.0.1")

②定义获得的目标ip对应的物理地址,这里应采用定义:

Dim Maca(1) As Long

③调用SendARP函数:

PhyaddrL = 6

r = SendARP(Dip, Sip, Maca(0), PhyaddrL)

④如果探测的目标地址不存在,产生错误31,否则SendARP将返回0

Print Hex(Maca(0)), Hex(Maca(1))

'注意显示值为 aabbccdd eeff  ,对应物理地址为 dd-cc-bb-aa-ff-ee

‘以下是真正的物理地址:

Print Right(Hex(Maca(0)), 2) & "-" & Mid(Hex(Maca(0)), 5, 2) & "-" & Mid(Hex(Maca(0)), 3, 2) & "-"; Left(Hex(Maca(0)), 2) & "-" & Right(Hex(Maca(1)), 2) & "-" & Left(Hex(Maca(1)), 2)

  


(未完,转下版)http://miaozk2006.blog.163.com/blog/static/38247058201111139156702/


VB部分相关推荐

VB快速读取 TextBox N 行的资料

VB禁止使用 Alt-Tab Ctrl-Alt-Del

生成迷宫的程序

另一方法转换大小写

VB控件注册 - 利用资源文件将dllocx打包进exe文件

VB利用资源文件进行工作

[]vb高效编程(优化)

VB阳历转阴历

VB代码取得硬盘的物理序列号

VB获得磁盘的文件系统

VB的,经常注册和反注册OCX控件和DLL

VB从程序中生成Exe文件

VB6监视/操作剪贴板示例(VB6.0代码)

VB6里自动提交/自动填表的一种相对通用的方案

VB移动没有标题的窗体

VB随机字母的函数

VB删除带子文件夹和文件的文件夹

VB怎样屏蔽 Alt+F4

VB 隐藏进程

vb屏蔽文本框点右键时的弹出菜单

VB手控Combobox的打开或收起

VBINI文件的读写、删除(对中文支持很好)

vb全局热键的写法(占很少的资源)

vb取消文本框的粘贴功能

VB常用文件操作类

VB获取特殊文件夹

VB获取windows各常用目录的函数(模块)

VB生成太极图

VB:常用内部函数大全,你会了几个呢?

vbSendMessage函数

精简VB程序的代码

VB:将数字转换为大写中文

VB:设定 MsgBox 在若干时间之后若无回应则自动关闭

VB:读取及设定NumLock/CapsLock/ScrollLock的值

VB:您知道 Mid$ 函量可以放在 '=' 的左方吗

VB后台获得按键,并执行自己的函数(非钩子及热键)

VB:将短文件名格式转成长文件名

vb中使用Iphlpapi.dll获取网络信息(上)

vb中使用Iphlpapi.dll获取网络信息(下)


更多精彩>>>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值