vb中從域名得到IP及從IP得到域名 (轉)
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 WYS_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 gethostbyaddr Lib "WSOCK32.DLL" (addr As Any, ByVal _
byteslen As Integer, addrtype As Integer) As Long
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 gethostbyname Lib "WSOCK32.DLL" (ByVal _
hostname$) As Long
Private Declare Sub RtlMoveMemory Lib "KERNEL32" (hpvDest As Any, _
ByVal hpv&, ByVal cbCopy&)
Function hibyte(ByVal wParam As Integer) '獲得整數的高位
hibyte = wParam &H100 And &HFF&
End Function
Function lobyte(ByVal wParam As Integer) '獲得整數的低位
lobyte = wParam And &HFF&
End Function
Function 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
MsgBox "Winsock.dll 沒有反應."
End
End If
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 = " Sockets版本 " & sLowByte & "." & sHighByte
sMsg = sMsg & " 不被winsock.dll支援 "
MsgBox sMsg
End
End If
If WSAD.iMaxSockets < MIN_SOCKETS_REQD Then
sMsg = "這個需要的最少Sockets數為 "
sMsg = sMsg & Trim$(str$(MIN_SOCKETS_REQD))
MsgBox sMsg
End
End If
End Function
Sub SocketsCleanup()
Dim lReturn As Long
lReturn = WSACleanup()
If lReturn <> 0 Then
MsgBox "Socket錯誤 " & Trim$(str$(lReturn)) & " occurred in Cleanup "
End
End If
End Sub
Sub Form_Load()
'初始化Socket
SocketsInitialize
End Sub
Private Sub Form_Unload(Cancel As Integer)
'清除Socket
SocketsCleanup
End Sub
Private Function getip(name As String) As String
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
hostent_addr = gethostbyname(name)
If hostent_addr = 0 Then
get= "" '主機名不能被解釋
Exit Function
End If
RtlMoveMemory host, hostent_addr, LenB(host)
RtlMoveMemory hostip_addr, host.hAddrList, 4
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)
getip = ip_address
End Function
Private Sub Command1_click()
Dim str As String
str = getip(Text1.Text)
If str = "" Then
Text2.Text = "主機名不能被解釋"
Else
Text2.Text = str
End If
End Sub
Private Function getname(addrstr As String) As String
Dim hostent_addr As Long
Dim host As HOSTENT
Dim addr(0 To 50) As Byte
Dim addrs As String
Dim hname(1 To 50) As Byte
Dim str As String
Dim i As Integer, j As Integer
Dim temp_int As Integer
Dim byt As Byte
str = Trim$(addrstr)
i = 0
j = 0
Do
temp_int = 0
i = i + 1
Do While Mid$(str, i, 1) >= "0" And Mid$(str, i, 1) <= "9" And i <= Len(str)
temp_int = temp_int * 10 + Mid$(str, i, 1)
i = i + 1
L
If temp_int <= 255 Then
addr(j) = temp_int
j = j + 1
End If
Loop Until Mid$(str, i, 1) <> "." Or i > Len(str) Or temp_int > 255
If temp_int > 255 Then
getname = "地址"
Exit Function
End If
hostent_addr = gethostbyaddr(addr(0), j, 2)
If hostent_addr = 0 Then
getname = "此地址無法解析"
Exit Function
End If
RtlMoveMemory host, hostent_addr, LenB(host)
RtlMoveMemory hname(1), host.hname, 50
j = 51
For i = 1 To 50
If hname(i) = 0 Then
j = i
End If
If i >= j Then
hname(i) = 32
End If
Next i
getname = Trim$(StrConv(hname, vbUnicode))
End Function
Private Sub Command2_Click()
Dim name As String
name = getname(Text2.Text)
If name = "" Then
name = "此地址沒有域名"
End If
Text1.Text = name
End Sub
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752043/viewspace-988398/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux下域名IP互轉Linux
- ping ip、域名、埠
- IP地址 、域名、 URL、 埠
- 域名和IP地址收集
- 從 Godaddy 轉移域名到 NamesiloGo
- 解析域名,獲取域名ip並輸出到終端
- 為什麼要並用域名和IP地址?域名和IP地址並用的理由
- 阿里雲如何繫結域名(阿里雲域名如何繫結ip)阿里
- 14IP地址、主機名、域名
- aws 的pod 有 ip 或者域名嗎
- IP頁面訪問域名介面問題
- 域名繫結動態IP實戰案例
- 看這位“翻譯官-DNS”如何轉換域名和IP地址DNS
- 可線上查詢子域名和同IP域名的RapidDNS聯動GobyAPIDNSGo
- 從建構函式得到引數型別函式型別
- 爬蟲實現:根據IP地址反查域名爬蟲
- 你的域名是如何變成 IP 地址的?
- c#中HttpWebRequest使用Proxy實現指定IP的域名請求C#HTTPWeb
- 公司官網建站筆記(四):從阿里雲將域名轉出,並將域名轉入騰訊雲筆記阿里
- openwrt 設定內網域名解析到指定ip內網
- SSL證書繫結域名還是繫結IP?
- 防止獨立IP被其它惡意域名惡意解析
- 域名和伺服器IP地址有什麼關係伺服器
- 如何進行動態ip的域名解析設定?
- [雜項]從子域名接管到Subtaker
- 5 個用於在 Linux 終端中查詢域名 IP 地址的命令Linux
- python爬蟲從ip池獲取隨機IPPython爬蟲隨機
- IP、域名和DNS的關係與區別是什麼?DNS
- 域名轉移影響域名解析嗎?
- 從JDK原始碼看Java域名解析JDK原始碼Java
- 主從DNS域名解析伺服器DNS伺服器
- 域名管理常見問題:IP、域名和DNS之間的區別和關係(中科三方)DNS
- nginx反向代理獲取客戶端的真實IP和域名Nginx客戶端
- IT職場:老闆可以從六西格瑪綠帶培訓中得到什麼
- 阿里雲域名解析與繫結伺服器IP地址—域名和埠訪問自己的web網站阿里伺服器Web網站
- 【SQL】SQL解惑-如何從字串中獲取IP地址SQL字串
- Keepalived+HAProxy基於ACL實現單IP多域名負載功能負載
- 關於Docker compose值IP與域名的對映 之 extra_hostDocker
- 【Linux小知識】網址、域名和ip的關係與區別!Linux