vb socket通信(TCP/UDP)一对一、多对一
VB Socket编程(Winsock控件创建TCP/IP客户机/服务器程序)
服务器程序的源代码如下:
[vb]
view>False
客户机程序使用的控件如下:
[vb]
view>False
建立多个客户端
Private intMax As Long
Private Sub Form_Load()
intMax = 0
sckServer(0).LocalPort = 1001
sckServer(0).Listen
End Sub
Private Sub sckServer_ConnectionRequest _
(Index As Integer,ByVal requestID As Long)
If Index = 0 Then
intMax = intMax + 1
Load sckServer(intMax)
sckServer(intMax).LocalPort = 0
sckServer(intMax).Accept requestID
Load txtData(intMax)
End If
End Sub
UDP 初步创建 UDP 应用程序比创建 TCP 应用程序还要简单,因为 UDP 协议不需要显式的连接。在上面的 TCP 应用程序中,一个 Winsock 控件必须显式地进行“监听”,另一个必须使用 Connect 方法初始化连接。 UDP 协议不需要显式的连接。要在两个控件中间发送数据,需要完成以下的三步(在连接的双方):
因为两台计算机的地位可以看成“平等的”,这种应用程序也被称为点到点的。为了具体说明这个问题,下面将创建一个“聊天”应用程序,两个人可以通过它进行实时的交谈。 要创建一个 UDP 伙伴,请按照以下步骤执行:
要创建第二个 UDP 伙伴,请按照以下步骤执行:
如果要试用上面的例子,按 F5 键运行工程,然后在两个窗体的 txtSend TextBox 中分别键入一些文本。键入的文字将出现在另一个窗体的 txtOutput TextBox 中。 关于 Bind 方法在上面的代码中,在创建 UDP 应用程序时调用了 Bind 方法,这是必须的。Bind 方法的作用是为控件“保留”一个本地端口。例如,如果将控件绑定到 1001 号端口,那么其它应用程序将不能使用该端口进行“监听”。该方法阻止其它应用程序使用同样的端口。 Bind 方法的第二个参数是任选的。如果计算机上存在多个网络适配器,可以用 LocalIP 参数来指定使用哪一个适配器。如果忽略该参数,控件使用的将是计算机上“控制面板”设置中“网络”控制面板对话框中列出的第一个适配器。 在使用 UDP 协议的时候,可以任意地改变 RemoteHost 和 RemotePort 属性,同时始终保持绑定在同一个 LocalPort 上。TCP 协议与此不同,在改变 RemoteHost 和 RemotePort 属性之前,必须先关闭连接。
————————————————————————————————————————————————————————————————————-
以上为介绍,可以有个大概的了解,也是转载的,不过当时情况混乱,没有附链接……
以下为完整的一个多对一的TCP通信实例,感谢原作者的帮助!转自:
http://www.cnblogs.com/findw/archive/2012/06/22/2558876.html
—————————————————————————————————————————————————————————————————————
1 通信程序通常都是采用Client/Server形式。这就要求作为服务器的主机可以同时处理多个客户的请求。因此在编写服务器程序时要添加多个Winsock控件。在开始我们先加入两个Winsock控件。其中一个用来侦听网上请求信号,取名为Listener;另外一个为初始的连接口,取名叫Sock(0)。注意,后一个控件要设为动态数组的形式,以后当客户增多时,可在这个控件基础上动态增加。由于受资源限制,我们在本例中设定最多可以同时接纳15个客户。客户机一般只与一个主机相连,因此程序只须一个Winsock进行连接就足够了。这个程序要用到的控件较少,除了Winsock和Form控件外,只须再添加Commmand控件即可。下面是具体程序和详细注释。 2 ****************************** 3 '服务器程序 4 ****************************** 5 Option Explicit 6 定义常量 7 Const BUSY As Boolean = False 8 Const FREE As Boolean = True 9 定义连接状态 10 Dim ConnectState() As Boolean 11 Private Sub Form_Load() 12 ReDim Preserve ConnectState(0 To 1) 13 On Error Resume Next 14 ConnectState(0) = FREE 15 ConnectState(1) = FREE 16 '指定网络端口号 17 Listener.LocalPort = 1011 18 '开始侦听 19 Listener.Listen 20 End Sub 21 Private Sub Listener_ConnectionRequest(ByVal requestID As Long) 22 Dim SockIndex As Integer 23 Dim SockNum As Integer 24 On Error Resume Next 25 Form1.Print requestID & "连接请求" 26 '查找连接的用户数 27 SockNum = UBound(ConnectState) 28 If SockNum > 14 Then 29 Form1.Print SockIndex & "" 30 Exit Sub 31 End If 32 '查找空闲的sock 33 SockIndex = FindFreeSocket() 34 '如果已有的sock都忙,而且sock数不超过15个,动态添加sock 35 If SockIndex > SockNum Then 36 Load Sock(SockIndex) 37 End If 38 ConnectState(SockIndex) = BUSY 39 Sock(SockIndex).Tag = SockIndex 40 '接受请求 41 Sock(SockIndex).Accept (requestID) 42 Form1.Print SockIndex & "接受请求" 43 End Sub 44 45 '客户断开,关闭相应的sock 46 Private Sub Sock_Close(Index As Integer) 47 If Sock(Index).State <> sckClosed Then 48 Sock(Index).Close 49 End If 50 ConnectState(Index) = FREE 51 Form1.Print Index & "close" 52 End Sub 53 54 '接收数据 55 Private Sub Sock_DataArrival(Index As Integer,ByVal bytesTotal As Long) 56 Dim dx As Double 57 Form1.Print "数据来自" & Index 58 Sock(Index).GetData dx,vbDouble 59 Form1.Print "dx=" & dx 60 End Sub 61 62 '寻找空闲的sock 63 Public Function FindFreeSocket() 64 Dim SockCount,i As Integer 65 SockCount = UBound(ConnectState) 66 For i = 0 To SockCount 67 If ConnectState(i) = FREE Then 68 FindFreeSocket = i 69 Exit Function 70 End Ifs 71 Next i 72 ReDim Preserve ConnectState(0 To SockCount + 1) 73 FindFreeSocket = UBound(ConnectState) 74 End Function 75 76 *************************** 77 '客户程序 78 ’*************************** 79 Option Explicit 80 '发送数据 81 Private Sub command1_Click() 82 Dim dx As Double 83 dx = 23.9 84 sock.SendData dx 85 MsgBox ("data sended") 86 End Sub 87 88 Private Sub Form_Load() 89 '远程主机名 90 sock.RemoteHost = "media2" 91 '网络端口 92 sock.RemotePort = 1011 93 '发出连接命令 94 sock.Connect 95 Command1.Enabled = False 96 End Sub 97 98 '服务器关闭 99 Private Sub sock_Close() 100 MsgBox ("socket closed") 101 End Sub 102 103 '连接成功 104 Private Sub sock_Connect() 105 MsgBox ("socket connected") 106 Command1.Enabled = True 107 End Sub 复制代码 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |