搜索
bottom↓
回复: 5

【转载】VB6获取本机IP的API,可以获取局域网IP和互联网IP【恢复】

[复制链接]

出0入22汤圆

发表于 2008-10-6 14:29:51 | 显示全部楼层 |阅读模式
Option Explicit



Private Const WS_VERSION_REQD = &H101

Private Const WS_VERSION_MAJOR = WS_VERSION_REQD \ &H100 And &HFF&

Private Const WS_VERSION_MINOR = WS_VERSION_REQD And &HFF&

Private Const MIN_SOCKETS_REQD = 1

Private Const SOCKET_ERROR = -1

Private Const WSADescription_Len = 256

Private Const WSASYS_Status_Len = 128



Private Type HOSTENT

    hName As Long

    hAliases As Long

    hAddrType As Integer

    hLength As Integer

    hAddrList As Long

End Type



Private Type WSADATA

    wversion As Integer

    wHighVersion As Integer

    szDescription(0 To WSADescription_Len) As Byte

    szSystemStatus(0 To WSASYS_Status_Len) As Byte

    iMaxSockets As Integer

    iMaxUdpDg As Integer

    lpszVendorInfo As Long

End Type



Private Declare Function WSAGetLastError Lib "WSOCK32.DLL" () As Long

Private Declare Function WSAStartup Lib "WSOCK32.DLL" (ByVal wVersionRequired&, lpWSAData As WSADATA) As Long

Private Declare Function WSACleanup Lib "WSOCK32.DLL" () As Long

Private Declare Function gethostname Lib "WSOCK32.DLL" (ByVal hostname$, ByVal HostLen As Long) As Long

Private Declare Function gethostbyname Lib "WSOCK32.DLL" (ByVal hostname$) As Long

Private Declare Sub RtlMoveMemory Lib "kernel32" (hpvDest As Any, ByVal hpvSource&, ByVal cbCopy&)







Private Function hibyte(ByVal wParam As Integer)

    hibyte = wParam \ &H100 And &HFF&

End Function





Private Function lobyte(ByVal wParam As Integer)

    lobyte = wParam And &HFF&

End Function





Private Sub SocketsInitialize()

    Dim WSAD As WSADATA

    Dim iReturn As Integer

    Dim sLowByte As String, sHighByte As String, sMsg As String

    

    iReturn = WSAStartup(WS_VERSION_REQD, WSAD)

    

    If iReturn = 0 Then

        If lobyte(WSAD.wversion) < WS_VERSION_MAJOR Or (lobyte(WSAD.wversion) = _

            WS_VERSION_MAJOR And hibyte(WSAD.wversion) < WS_VERSION_MINOR) Then

            sHighByte = Trim$(Str$(hibyte(WSAD.wversion)))

            sLowByte = Trim$(Str$(lobyte(WSAD.wversion)))

            sMsg = "Windows Sockets version " & sLowByte & "." & sHighByte

            'Debug.Print sMsg

            'sMsg = sMsg & " winsock.dll tarafindan desteklenmiyor. "

            'MsgBox sMsg

            'End

        End If

    Else

        'Debug.Print "Winsock.dll Error."

    End If



End Sub





Public Function GetCurrentIP(ByVal blnExternalIP As Boolean) As String



    Dim hostname As String * 256

    Dim hostent_addr As Long

    Dim host As HOSTENT

    Dim hostip_addr As Long

    Dim temp_ip_address() As Byte

    Dim i As Integer

    Dim ip_address As String

    Dim IP As String

    Dim Internal As String

    Dim EXTERNAL As String

    

    If gethostname(hostname, 256) <> SOCKET_ERROR Then

        hostname = Trim$(hostname)

        

        hostent_addr = gethostbyname(hostname)

        

        If hostent_addr <> 0 Then

            RtlMoveMemory host, hostent_addr, LenB(host)

            RtlMoveMemory hostip_addr, host.hAddrList, 4

            

            Do

                ReDim temp_ip_address(1 To host.hLength)

                RtlMoveMemory temp_ip_address(1), hostip_addr, host.hLength

                

                

                For i = 1 To host.hLength

                    ip_address = ip_address & temp_ip_address(i) & "."

                Next

                ip_address = Mid$(ip_address, 1, Len(ip_address) - 1)

                

                ' Return Both LAN and External IP Fix

                ' Master Yoda 30-05-2000

                ' ##########################################

                ' HERE'S THE PROBLEM!!!

                'TheIP = TheIP + ip_address

                ' ##########################################

                ' HERE'S THE FIX!!!

                Internal = IP ' Send ONLY the External IP to the CurrentIP Function

                EXTERNAL = ip_address ' Send the External IP to the function parameter External

                IP = ip_address ' Send LAN IP to the function para Internal

                

                ' You don't really need to return parameters,

                ' it just allows you to get both IPs :)

                ' ##########################################

                

                ip_address = ""

                host.hAddrList = host.hAddrList + LenB(host.hAddrList)

                RtlMoveMemory hostip_addr, host.hAddrList, 4

            Loop While (hostip_addr <> 0)

            

            If blnExternalIP = True Then

                GetCurrentIP = EXTERNAL

            Else

                GetCurrentIP = Internal

            End If

        Else

        'Debug.Print "Winsock.dll error."

        

        GetCurrentIP = ""

        End If

    Else

        'Debug.Print "Windows Socket Error " & Str(WSAGetLastError())

        

        GetCurrentIP = ""

    End If



End Function





Private Sub SocketsCleanup()

    

    Dim lReturn As Long

    

    lReturn = WSACleanup()

    

    If lReturn <> 0 Then

    'MsgBox "Socket Error " & Trim$(Str$(lReturn)) & " occurred In Cleanup "

    End If

End Sub





Private Sub Class_Initialize()



    SocketsInitialize



End Sub





Private Sub Class_Terminate()



    SocketsCleanup



End Sub

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2008-10-15 11:49:22 | 显示全部楼层
顶,收藏先!

出0入0汤圆

发表于 2008-10-6 20:38:54 | 显示全部楼层

出0入0汤圆

发表于 2011-10-8 15:00:00 | 显示全部楼层
收藏了..

出0入0汤圆

发表于 2011-10-11 14:51:33 | 显示全部楼层
shou cang

出0入0汤圆

发表于 2012-10-27 09:14:26 | 显示全部楼层
看了一下,但不知道怎么用……
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-23 18:21

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表