VB调用GetAdaptersInfo 的正确方法

前些天写了个小工具,需要知道网关的ip,上网搜了些方法,大多数都是用的 WMI,但是WMI的速度实在是慢,而且刚开机的话,是访问不了的,所以决定还是用系统调用的方法,可是网上的教程没有一个能在多网卡或多IP下用的,总是在 CopyMemory 时程序崩溃,没办法,只好自己找原因了,几次崩溃之后,终于找到了原因,在用 0& 调用后返回的AdapterInfoSize 在多网卡时,长度超过了IP_ADAPTER_INFO 结构,而所有教程都是用AdapterInfoSize 调用的CopyMemory ,所以程序崩溃就是必然了,找到问题,解决就相对简单了,用 sizeof(IP_ADAPTER_INFO)就对了,可惜VB 没有这个运算符,只好自己定义一个常量来代替,完整代码如下,希望能帮助一些人。 Public Const MAX_ADAPTER_NAME_LENGTH = 260Public Const MAX_ADAPTER_ADDRESS_LENGTH = 8Public Const MAX_ADAPTER_DESCRIPTION_LENGTH = 132Public Const IP_ADAPTER_INFO_LENGTH = 640 Type IP_ADDR_STRING            Next As Long            IpAddress As String * 16            IpMask As String * 16            Context As LongEnd Type 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            DhcpEnabled As Long            CurrentIpAddress As Long            IpAddressList As IP_ADDR_STRING            GatewayList As IP_ADDR_STRING            DhcpServer As IP_ADDR_STRING            HaveWins As Byte            PrimaryWinsServer As IP_ADDR_STRING            SecondaryWinsServer As IP_ADDR_STRING            LeaseObtained As Long            LeaseExpires As LongEnd Type Public Declare Function GetAdaptersInfo Lib "iphlpapi.dll" (IpAdapterInfo As Any, pOutBufLen As Long) As LongPrivate Declare Sub CopyMemory Lib "kernel32.dll" Alias "RtlMoveMemory" (ByRef Destination As Any, ByRef Source As Any, ByVal Length As Long) Public Function GetewayIP() As String    Dim AdapterInfoSize As Long    Dim AdapterInfo As IP_ADAPTER_INFO    Dim AdapterInfoBuffer() As Byte    Dim ptr1 As Long        AdapterInfoSize = 0    Call GetAdaptersInfo(ByVal 0&, AdapterInfoSize)    ReDim AdapterInfoBuffer(AdapterInfoSize - 1)    If 0 = GetAdaptersInfo(AdapterInfoBuffer(0), AdapterInfoSize) Then        ptr1 = VarPtr(AdapterInfoBuffer(0))        Do While (ptr1 <> 0)            CopyMemory AdapterInfo, ByVal ptr1, IP_ADAPTER_INFO_LENGTH            If InStr(AdapterInfo.GatewayList.IpAddress, Chr(0)) > 6 Then                GetwayIP = Left(AdapterInfo.GatewayList.IpAddress, InStr(AdapterInfo.GatewayList.IpAddress, Chr(0)) - 1)                Exit Function            End If            ptr1 = AdapterInfo.Next        Loop    End IfEnd Function
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值