WhoIs服务允许你获得有关域名所有者,电子邮件地址所有者的有关信息。所有的信息储存在Internic的数据库中。这个不会向服务器发送任何命令。你只需要通过rs.internic.net的43号端口同服务器建立连接,然后发送你要查的域名或电子邮件地址就行了。如果找不到你要查找的信息,服务器会告诉你信息未找到,然后服务器将关闭与你的连接。
打开一个新的工程(都成一句废话了)。将Winsock控件添加到窗体中:
将txtResponse文本框控件的属性作小小的修改:MultyLine=True,ScrollBars - "3 - Both". 将下面的代码粘贴到相应的事件中:
Private Sub Command1_Click()
txtResponse = ""
Winsock1.Close
Winsock1.LocalPort = 0
Winsock1.Connect "rs.internic.net", 43
End Sub
Private Sub Command2_Click()
txtSearch = ""
txtResponse = ""
End Sub
Private Sub Winsock1_Connect()
Winsock1.SendData txtSearch & vbCrLf
End Sub
Private Sub Winsock1_DataArrival(ByVal bytesTotal As Long)
Dim strData As String
On Error Resume Next
Winsock1.GetData strData
txtResponse = txtResponse & strData
End Sub
请务必记住在尾处加上vbLf,表示要传送的文本的结束,否则服务器会一直在那里傻等。这点对任何Internet协议都适用。
运行程序后在文本框中输入要查找的东西,例如oracle.com,然后按Lookup按钮。几秒钟之后服务器会将查到的资料返回给你。这些信息看起来象下面这个衰样。
原因是UNIX系统用相当于VB的vbLf来作为分行符,而不是vbCrLf。所以为了读起来更容易一些,你需要对收到的信息作一点处理。如果你用的是VB6,可以用下面的语句,用vbCrLf代替掉vbLf。
strData = Replace(strData, vbLf, vbCrLf)
Now the Winsock1_DataArrival event should look like this:
Private Sub Winsock1_DataArrival(ByVal bytesTotal As Long)
Dim strData As String
On Error Resume Next
Winsock1.GetData strData
strData = Replace(strData, vbLf, vbCrLf)
txtResponse = txtResponse & strData
End Sub
如果你要查某人的电子邮件地址,输入名字就行了。比如说 "gates,bill"。服务器会返回所有符合条件的记录。其中紧跟在名称后面的括号内是记录的ID。你也可以直接输入ID去查,但记住在ID前面加一个感叹号。
- 还没有人评论,欢迎说说您的想法!