
No.1ベストアンサー
- 回答日時:
'***共通***
Private Const WS_VERSION_REQD = &H101
Private Const WSADescription_Len = 256
Private Const WSASYS_Status_Len = 128
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 Type HOSTENT
hName As Long
hAliases As Long
hAddrType As Integer
hLength As Integer
hAddrList As Long
End Type
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 Sub RtlMoveMemory Lib "kernel32" (hpvDest As Any, ByVal hpvSource&, ByVal cbCopy&)
'***ホスト名→IP***
Private Declare Function gethostbyname Lib "WSOCK32.DLL" (ByVal HostName$) As Long
'***IP→ホスト名***
Private Declare Function gethostbyaddr Lib "wsock32.dll" (addr As Long, ByVal lngLen As Long, ByVal lngType As Long) As Long
'ホスト名→IPの例
Dim WSAD As WSADATA
Dim lRet As Integer
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
'Winsockの使用を開始
lRet = WSAStartup(WS_VERSION_REQD, WSAD)
hostent_addr = gethostbyname("ホスト名")
If hostent_addr = 0 Then
'失敗
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)
'ホスト名ゲット
Text.Text = ip_address
'Winsockの使用を終了
lRet = WSACleanup()
ホスト名→IPは以下のURLを参照
http://vbvbvb.com/jp/gtips/0851/ggethostbyaddr.h …
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ネットワーク上のPCのIPとホス...
-
WindowsでS.M.A.R.Tの情報取得...
-
名前が二重に定義されています
-
winsock通信時エラーの回避
-
エクセルVBA 宣言Dimの場所
-
ASP.net の OnClientClick
-
ASP 0x80004005 クライアント...
-
CreateObject("Excel.Applicati...
-
GridView表示の高速化
-
EXECLマクロでshapeがグルーフ...
-
VB6でRDOに接続できない
-
SQLサーバーへの接続に 接...
-
VBSにてサーバー中のエクセルフ...
-
CAsyncSocket::Create()がエラ
-
式はメソッドではありませんと...
-
CreateProcessでアプリケーショ...
-
隠しフィールドをVBScriptでの...
-
【C#】アップロード時に「アプ...
-
ActiveDirectoryで高い層のOUを...
-
C# try-catch でcatchに飛ばす方法
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ネットワーク上のPCのIPとホス...
-
Cプログラム UDP送信の送信...
-
WindowsでS.M.A.R.Tの情報取得...
-
C# try-catch でcatchに飛ばす方法
-
ソケット通信で同時受信の制限?
-
EXECLマクロでshapeがグルーフ...
-
エクセルVBA 宣言Dimの場所
-
GridView表示の高速化
-
式はメソッドではありませんと...
-
FileCopy時のエラー
-
Response.Redirectで引数2つの...
-
ASP更新・変更ができない
-
CreateObject("Excel.Applicati...
-
ASP 0x80004005 クライアント...
-
Panelを重ねる方法
-
ASP内で他のASPファイルを読み...
-
名前が二重に定義されています
-
このページの状態情報は無効で...
-
「Scripting.FileSystemObject...
-
ページの更新内容が反映されない。
おすすめ情報