|
Imports System.Net
Imports System.Net.Sockets
Imports System.Net.Sockets.Socket
Imports System.Collections.Specialized
Public Class GetServers
'采用udp协议
Private m_Client As Sockets.UdpClient
'广播地址,表示整个网络
Private StrHost As String = "255.255.255.255"
'广播端口
Private IntPort As Integer = 1434
'要发送的数据,发送这个数据所有的sqlserver就会响应了
Private B() As Byte = New Byte() {&H2}
'因为 send 里面有个死循环,这里用个定时器来处理超时间
Private WithEvents t As New Timers.Timer
'发送数据出去
Function Send() As ArrayList
m_Client = New UdpClient
'用来存储获取的sql列表
Dim atemp As New ArrayList
'发送的目标,广播地址
Dim host As New IPEndPoint(IPAddress.Parse(Me.StrHost), Me.IntPort)
Try
'这里发送数据
m_Client.Send(B, 1, host)
'下面开始读取,因为网络内sql server数量众多,数据包一个一个的返回
'所以这里循环处理了。
While True
'开定时器
t.Interval = 1000
t.Enabled = True
'接收的字节数组
Dim BR As Byte() = m_Client.Receive(host)
Dim A As System.Text.Encoding = System.Text.Encoding.Default
'用来存储当前字符串
Dim S As String = ""
'从第4个数字开始,前三个字符为非打印字符
S = A.GetString(BR, 3, BR.Length - 3)
Console.WriteLine(S)
'这里解析获取的文本
atemp.Add(New SqlServer(S))
'关闭
t.Enabled = False
End While
Catch ex As Exception
Console.WriteLine(ex.Message)
Finally
m_Client.Close()
End Try
Return atemp
'Console.WriteLine("检查完毕。。")
End Function
'超时后强制结束网络等待。
Private Sub t_Elapsed(ByVal sender As Object, ByVal e As System.Timers.ElapsedEventArgs) Handles t.Elapsed
'Console.WriteLine("关闭。。")
m_Client.Close()
t.Dispose()
End Sub
End Class
Public Class SqlServer
'sql server解析类
'
'因为返回的字符串类似 name1;value1;name2;value2;name3;value3; ....
'而且不固定长度
'所以这里用NameValueCollection返回。
Private Nv As NameValueCollection
Sub New(ByVal Str As String)
Nv = New NameValueCollection
Dim a As String() = Str.Split(";")
For i As Integer = 0 To a.Length - 1 Step 2
Dim t As Integer = i
Nv(a(t)) = a(t + 1)
Next
End Sub
'因为要添加到combobox,这里重载了一下tostring以显示文本
Overrides Function tostring() As String
Return Nv("ServerName")
End Function
End Class |