vb.net局域网聊天气 vbnet socket

求利用vb做的一个可以在局域网聊天 , 传文件的程序去看下 MSDN 中有关 Winsock 控件的部分吧
---------
使用 Winsock 控件
利用 WinSock 控件可以与远程计算机建立连接,并通过用户数据文报协议 (UDP)或者传输控制协议 (TCP)进行数据交换 。这两种协议都可以用来创建客户与服务器应用程序 。与 Timer 控件类似,WinSock 控件在运行时是不可见的 。
可能的用途
创建收集用户信息的客户端应用程序,并将收集的信息发送到某中央服务器 。
创建一个服务器应用程序,作为多个用户的数据的汇入点 。
创建“聊天”应用程序 。
选择通讯协议
在使用 WinSock 控件时,首先需要考虑使用什么协议 。可以使用的协议包括 TCP 和 UDP 。两种协议之间的重要区别在于它们的连接状态:
TCP 协议控件是基于连接的协议,可以将它同电话系统相比 。在开始数据传输之前 , 用户必须先建立连接 。
UDP 协议是一种无连接协议,两台计算机之间的传输类似于传递邮件:消息从一台计算机发送到另一台计算机,但是两者之间没有明确的连接 。另外,单次传输的最大数据量取决于具体的网络 。
到底选择哪一种协议通常是由需要创建的应用程序决定的 。下面的几个问题将有助于选择适宜的协议:
在收发数据的时候,应用程序是否需要得到客户端或者服务器的确认信息?如果需要 , 使用 TCP 协议,在收发数据之前先建立明确的连接 。
数据量是否特别大(例如图象与声音文件)?在连接建立之后,TCP 协议将维护连接并确保数据的完整性 。不过 , 这种连接需要更多的计算资源,因而是比较“昂贵”的 。
数据发送是间歇的,还是在一个会话内?例如,如果应用程序在某个任务完成的时候需要通知某个计算机,UDP 协议是更适宜的 。UDP 协议适合发送少量的数据 。
协议的设置
在设计时,可以按如下方式设置应用程序使用的协议:在“属性”窗口中单击“协议”,然后选择 sckTCPProtocol 或者 sckUDPProtocol 。也可以使用程序代码来设置 Protocol 属性,如下所示:
Winsock1.Protocol = sckTCPProtocol
确定计算机的名称
在与远程计算机相连接的时候,需要知道它的 IP 地址或者它的“好听的名字” 。IP 地址是一串数字 , 每三个数字为一组,中间用点隔开(形如 xxx.xxx.xxx.xxx) 。通常,最易记住的是计算机的“好听的名字” 。
要确定计算机的名字,请按照以下步骤执行:
在计算机的“任务栏”上,单击“启动” 。
在“设置”项中 , 单击“控制面板” 。
双击“网络”图标 。
单击“标识”选项卡 。
在“计算机名称”框中可以找到计算机的名称 。
上面找到的计算机名称可以作为 RemoteHost 属性的值 。
TCP 连接初步
如果应用程序要使用 TCP 协议,那么首先必须决定应用程序是服务器还是客户端 。如果要创建一个服务器端,那么应用程序需要“监听”指定的端口 。当客户端提出连接请求时,服务器端能够接受请求并建立连接 。在连接建立之后,客户端与服务器端可以自由地互相通讯 。
下列步骤创建一个非常简单的服务器:
要创建一个 TCP 服务器,请按照以下步骤执行:
创建新的 Standard EXE 工程 。
将缺省窗体的名称改为 frmServer 。
将窗体的标题改为“TCP 服务器” 。
在窗体中放入一个 Winsock 控件,并将它的名字改为 tcpServer 。
在窗体上添加两个 TextBox 控件 。将第一个命名为 txtSendData , 第二个为 txtOutput 。
为窗体添加如下的代码 。
Private Sub Form_Load()
'将 LocalPort 属性设置为一个整数 。
'然后调用 Listen 方法 。
tcpServer.LocalPort = 1001
tcpServer.Listen
frmClient.Show '显示客户端的窗体 。
End Sub
Private Sub tcpServer_ConnectionRequest _
(ByVal requestID As Long)
'检查控件的 State 属性是否为关闭的 。
'如果不是,
'在接受新的连接之前先关闭此连接 。
If tcpServer.StatesckClosed Then _
tcpServer.Close
'接受具有 requestID 参数的
'连接 。
tcpServer.Accept requestID
End Sub
Private Sub txtSendData_Change()
'名为 txtSendData 的 TextBox 控件中
'包含了要发送的数据 。当用户往文本框中
'键入数据时 , 使用 SendData 方法
'发送输入的字符串 。
tcpServer.SendData txtSendData.Text
End Sub
Private Sub tcpServer_DataArrival _
(ByVal bytesTotal As Long)
'为进入的数据声明一个变量 。
'调用 GetData 方法,并将数据赋予名为 txtOutput
'的 TextBox 的 Text 属性 。
Dim strData As String
tcpServer.GetData strData
txtOutput.Text = strData
End Sub
上面的步骤创建了一个简单的服务器应用程序 。为了使它能够工作,还必须为它创建一个客户端的应用程序 。
要创建 TCP 客户端 , 请按照以下步骤执行:
在工程中添加一个新的窗体,将其命名为 frmClient 。
将窗体的标题改为“TCP Client” 。
在窗体中添加一个 Winsock 控件,并将其命名为 tcpClient 。
在 frmClient 中添加两个 TextBox 控件 。将第一个命名为 txtSend,第二个为 txtOutput 。
在窗体上放一个 CommandButton 控件,并将其命名为 cmdConnect 。
将 CommandButton 控件的标题改为 Connect 。
在窗体中添加如下的代码 。
重点必须将 RemoteHost 属性值修改为您的计算机的名字 。
Private Sub Form_Load()
'Winsock 控件的名字为 tcpClient 。
'注意:要指定远程主机,可以使用
' IP 地址(例如:"121.111.1.1"),也可以使用
'计算机的“好听的名字”如下所示 。
tcpClient.RemoteHost = "RemoteComputerName"
tcpClient.RemotePort = 1001
End Sub
Private Sub cmdConnect_Click()
'调用 Connect 方法,初始化连接 。
tcpClient.Connect
End Sub
Private Sub txtSendData_Change()
tcpClient.SendData txtSend.Text
End Sub
Private Sub tcpClient_DataArrival _
(ByVal bytesTotal As Long)
Dim strData As String
tcpClient.GetData strData
txtOutput.Text = strData
End Sub
上面的代码创建了一个简单的客户/服务器模式的应用程序 。我们可以将两者都运行起来:运行工程,然后单击“连接” 。在两个窗体之一的 txtSendData 文本框中键入文本,可以看到同样的文字将出现在另一个窗体的 txtOutput 文本框中 。
接受多个连接请求
上面设计的基本服务器只能接受一个连接请求 。通过创建控件数组,使用一个控件也可以同时接受多个连接请求 。利用这种方法,不需要关闭连接,而只需创建新的控件实例(通过设置其索引属性),然后在新的实例上调用 Accept 方法 。
下面的代码假定名为 sckServer 的窗体上有一个 Winsock 控件 , 它的 Index 属性被设置为 0;因此控件是控件数组的一部分 。在声明部分 , 声明了一个模块级的变量 intMax 。在窗体的 Load 事件中 , intMax 被设置为 0,数组中第一个控件的 LocalPort 属性被设置为 1001 。然后调用控件的 Listen 方法,使之成为“监听”控件 。在连接请求到达时,代码将检测 Index 是否为 0(“监听”控件的值) 。如果为 0,监听控件将增加 intMax 的值,并使用该号码来创建新的控件实例 。然后,使用新的控件实例接受连接请求 。
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 = intMax1
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 协议不需要显式的连接 。要在两个控件中间发送数据,需要完成以下的三步(在连接的双方):
将 RemoteHost 属性设置为另一台计算机的名称 。
将 RemotePort 属性设置为第二个控件的 LocalPort 属性 。
调用 Bind 方法,指定使用的 LocalPort 。(下面将详细地讨论该方法 。)
因为两台计算机的地位可以看成“平等的”,这种应用程序也被称为点到点的 。为了具体说明这个问题 , 下面将创建一个“聊天”应用程序,两个人可以通过它进行实时的交谈 。
要创建一个 UDP 伙伴,请按照以下步骤执行:
创建一个新的 Standard EXE 工程 。
将缺省的窗体的名称修改为 frmPeerA 。
将窗体的标题修改为“Peer A” 。
在窗体中放入一个 Winsock 控件,并将其命名为 udpPeerA 。
在“属性”页上,单击“协议”并将协议修改为 UDPProtocol 。
在窗体中添加两个 TextBox 控件 。将第一个命名为 txtSend,第二个命名为 txtOutput 。
为窗体增加如下的代码 。
Private Sub Form_Load()
'控件的名字为 udpPeerA
With udpPeerA
'重点:必须将 RemoteHost 的值
'修改为计算机的名字 。
.RemoteHost= "PeerB"
.RemotePort = 1001'连接的端口号 。
.Bind 1002'绑定到本地的端口 。
End With
frmPeerB.Show'显示第二个窗体 。
End Sub
Private Sub txtSend_Change()
'在键入文本时,立即将其发送出去 。
udpPeerA.SendData txtSend.Text
End Sub
Private Sub udpPeerA_DataArrival _
(ByVal bytesTotal As Long)
Dim strData As String
udpPeerA.GetData strData
txtOutput.Text = strData
End Sub
要创建第二个 UDP 伙伴,请按照以下步骤执行:
在工程中添加一个标准窗体 。
将窗体的名字修改为 frmPeerB 。
将窗体的标题修改为“Peer B” 。
在窗体中放入一个 Winsock 控件 , 并将其命名为 udpPeerB 。
在“属性”页上,单击“协议”并将协议修改为“UDPProtocol” 。
在窗体上添加两个 TextBox 控件 。将第一个命名为 txtSend,第二个命名为 txtOutput 。
在窗体中添加如下的代码 。
Private Sub Form_Load()
'控件的名字为 udpPeerB 。
With udpPeerB
'重点:必须将 RemoteHost 的值改为
'计算机的名字 。
.RemoteHost= "PeerA"
.RemotePort = 1002'要连接的端口 。
.Bind 1001'绑定到本地的端口上 。
End With
End Sub
Private Sub txtSend_Change()
'在键入后立即发送文本 。
udpPeerB.SendData txtSend.Text
End Sub
Private Sub udpPeerB_DataArrival _
(ByVal bytesTotal As Long)
Dim strData As String
udpPeerB.GetData strData
txtOutput.Text = strData
End Sub
如果要试用上面的例子,按 F5 键运行工程 , 然后在两个窗体的 txtSend TextBox 中分别键入一些文本 。键入的文字将出现在另一个窗体的 txtOutput TextBox 中 。
关于 Bind 方法
在上面的代码中,在创建 UDP 应用程序时调用了 Bind 方法,这是必须的 。Bind 方法的作用是为控件“保留”一个本地端口 。例如,如果将控件绑定到 1001 号端口,那么其它应用程序将不能使用该端口进行“监听” 。该方法阻止其它应用程序使用同样的端口 。
Bind 方法的第二个参数是任选的 。如果计算机上存在多个网络适配器,可以用 LocalIP 参数来指定使用哪一个适配器 。如果忽略该参数 , 控件使用的将是计算机上“控制面板”设置中“网络”控制面板对话框中列出的第一个适配器 。
在使用 UDP 协议的时候 , 可以任意地改变 RemoteHost 和 RemotePort 属性,同时始终保持绑定在同一个 LocalPort 上 。TCP 协议与此不同 , 在改变 RemoteHost 和 RemotePort 属性之前,必须先关闭连接 。
用vb.net实现网络通信用 vb.net socket通信
Dim th As Threading.Thread
2Dim tcpl As System.Net.Sockets.TcpListener
3
4Private Sub Form1_Load()Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
5th = New System.Threading.Thread(New System.Threading.ThreadStart(AddressOf MyListen))
6th.Start()
7End Sub
8
9Public Sub SendMessage()Sub SendMessage(ByVal IP As String, ByVal SendMsg As String)
10Try
11If IP"" Then
12Dim tcpc As New System.Net.Sockets.TcpClient(IP, 5656)
13Dim tcpStream As Net.Sockets.NetworkStream = tcpc.GetStream
14Dim reqStream As New IO.StreamWriter(tcpStream)
15reqStream.Write(SendMsg)
16reqStream.Flush()
17tcpStream.Close()
18tcpc.Close()
19End If
20Catch ex As Exception
21MsgBox(ex.Message.ToString)
22End Try
23End Sub
24Private Sub MyListen()Sub MyListen()
25Try
26Dim ipAddress As System.Net.IPAddress = System.Net.Dns.Resolve(System.Net.Dns.GetHostName).AddressList(0)
27tcpl = New System.Net.Sockets.TcpListener(ipAddress, 5656)
28tcpl.Start()
29While True
30Dim s As System.Net.Sockets.Socket = tcpl.AcceptSocket()
31Dim MyBuffer(1024) As Byte
32Dim i As Integer
33i = s.Receive(MyBuffer)
34If i0 Then
35Dim lstrRec As String
36Dim j As Integer
37For j = 0 To i - 1
38TextBox1.Text= Chr(MyBuffer(j))","
39Next
40End If
41End While
42Catch ex As Exception
43MsgBox(ex.Message.ToString)
44End Try
45End Sub
46
47Private Sub Button1_Click()Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
48SendMessage("192.168.0.61", TextBox2.Text)
49End Sub
VB编写的局域网聊天工具源代码用VB做聊天程序的方法
---- 所谓"聊天"是指两个程序能够发送数据给对方 。这个程序涉及到数据通讯的知识,仿佛很复杂 , 不过,由于VB给我们提供了一个Winsock控件,问题就变得很简单了 。
---- 先编写"聊天(主机)"程序 。在窗体里添加Winsock控件,并设置其Protocol属性为1-SckUDPProtocol , 其他属性为缺省值 。接着添加两个标签和两个文本框 , 设置两个标签的标题属性分别为"接收窗"和"发送窗";两个文本框的标题属性为空 。最后编写代码:
---- 1."聊天(主机)"
Private Sub Form-Load()
′设置网络地址
Winsock1.LocalPort=1024
Winsock1.RemoteHost="202.96.6.1"
Winsock1.RemotePort=1999
End Sub
【vb.net局域网聊天气 vbnet socket】Private Sub Text1-Change()
′发送用户输入的内容
Winsock1.SendData Text1.Text
End Sub
Private Sub Winsock1-DataArrival
(Byval bytesTotal As Long)
Dim rec As String
′接收对方数据并在文本框内显示
Winsock1.GetData rec, vb String
Text2.Text=rec
End Sub
---- 2."聊天(副机)"
Private Sub Form_Load()
′设置网络地址
Winsock1.LocalPort=1999
Winsock1.RemoteHost="202.96.6.1"
Winsock1.RemotePort=1024
---- 其他部分程序与(主机)相同 。最后将两个程序存盘,并编译成执行(.Exe)文件 。现在就可以使用这个程序进行对话了 。
---- 七.文本框中文本的某一特定字符或字符串同时高亮显示的方法
---- 由于普通TextBox控件不支持不连续字符串的同时高亮显示,所以我们选择RichTextBox控件 。单击工程(Project)选单项,在弹出的下拉选单中单击组件(Components)选单项,从弹出的对话框中选择Microsoft Rich Textbox Control 5.0复选框,确定加载RichTextBox控件 。
---- 新建(New)一个工程,在窗体(Form)上添加一个RichTextBox控件和两个Command(按钮)控件,都采用系统默认的Name属性值;设置RichTextBox的Text属性值为空,Command1和Command2的Caption属性值分别设为"输入文本"和"选择字符串" 。最后,添加如下VB代码:
Private Sub Command1-Click()
Dim str As String
Dim Text As String
str=〃输入文本〃
Text=InputBox(str)
RichTextBox1.Text=Text
End Sub
Private Sub Command2-Click()
Dim str As String
Dim Text As String
Dim Position As Integer
Dim Lenth As Integer
str=〃输入要高亮显示的字符串〃
Text=InputBox(str)
If Text 〈〉 〃〃 Then
Position=InStr(RichTextBox1.Text, Text)-1
Lenth=Len(Text)
RichTextBox1.SelStart=Position
RichTextBox1.SelLength=Lenth
RichTextBox1.SelColor=RGB(255,0,0)
Do While InStr(Position+Lenth+
1, RichTextBox1.Text, Text) 〈〉 0
Position=InStr(Position+Lenth+
1, RichTextBox1.Text, Text)-1
RichTextBox1.SelStart=Position
RichTextBox1.SelLength=Lenth
RichTextBox1.SelColor=RGB(255,0,0)
Loop
End If
End Sub
---- 按F5执行程序,单击"输入文本"按钮 , 在弹出的对话框中输入一些文本 , 确定后,刚刚输入的文本将显示在RichTextBox中;再单击"选择字符串"按钮,在弹出的对话框中输入你希望高亮显示的字符串,确定后,RichTextBox中相应的字符串将以红色高亮显示 。
---- 八.编程实现Windows 95/98操作系统热启动的方法
---- 要利用程序实现系统的重新启动,可以在你的程序中调用API函数来实现 。建一个子函数:(以VB为例)
Declare Function SystemParametersInfo Lib 〃
user32〃 Alias -
〃SystemParametersInfo〃 (ByVal uAction As Long,
ByVal uParam As Long,
ByVal lpvParam As Any, ByVal
fuWinIni As Long) As Long
Sub DisableCtrlAltDelete(bDisabled As Boolean)
Dim X As Long
X=SystemParametersInfo(97, bDisabled, CStr(1), 0)
End Sub
Call DisableCtrlAltDelete(true) ′禁止热启
Call DisableCtrlAltDelete(false) ′允许热启
---- 九.在Windows 95/ 98启动后自动启动程序的方法
---- 我们都知道在Windows 95/98的"开始"→"程序"选单下有一"启动"选单项 , 当每次启动Windows 95或Windows 98时,系统都会自动启动放在"启动"选单栏里的可执行程序 。
---- 但目前有好多软件,像解霸五、ICQ,以及大部分实时侦测病毒的软件等等 , 安装后,并没有放在"启动"选单里,也能在启动操作系统时自动启动 。怎么实现的呢?
---- 其实只要知道Windows注册表的一些知识,这个问题就不能称之为问题了 。用鼠标单击"开始",打开开始选单,再单击"运行",出现一对话框,然后输入"regedit",确定后 , 会打开系统注册表编辑器,找到HKEY-LOCAL-MACHINE? SOFTWARE?Microsoft?Windows?CurrentVersion?Run,加入你的程序的入口 , 就可以了 。如果不知道怎么加 , 就参考一下已经存在的键值 。
---- 十. 如何把数据文件输出到Text控件中?如果数据量比较大,窗体满屏也不够大 , 怎么解决?
---- 有一个比较简单的方法,就是把数据放到一个文本框(Text)里,并在其中加上水平和垂直滚动条 。具体实现步骤为:先在窗体(Form)里加入一个文本框,采用默认名Text1;然后,设置文本框Text1的属性:Text属性设置为空,MultiLine属性设置为True,ScrollBars属性设置为3-Both;接着添加如下VB代码:
Private Sub Form-Load()
Dim Handle As Integer
Dim FileName As String
On Error GoTo ErrExit
begin:
′输入要显示的数据文件的名称
FileName=InputBox$(〃Input Filename〃,
〃Open File〃)
On Error GoTo FileErr
Handle=FreeFile
Open FileName For Input As #Handle
′把数据文件中的数据输出到文本框中
Text1.Text=Input$(LOF(Handle), Handle)
Close #Handle
Exit Sub
FileErr:
Dim ErrNum As Integer
If Err.Number=53 Then
ErrNum=MsgBox(〃File not exist〃,
vbOKCancel, 〃Error Information〃)
If ErrNum=1 Then
GoTo begin
Else
Exit Sub
End If
End If
MsgBox Err.Description, , 〃file open failed〃
ErrExit:
Exit Sub
End Sub
′使文本框充满整个窗体
Private Sub Form-Resize()
Text1.Left=0
Text1.Top=0
Text1.Width=Form1.Width-100
Text1.Height=Form1.Height-400
End Sub
---- 通过这样的处理,不仅能解决问题,而且用户还可以在文本框中对数据进行编辑 。
---- 十一.关联文件列表框、目录列表框和驱动器列表框的方法
---- 想做一个对话窗体,包含驱动器列表框、目录列表框和文件列表框 , 并能实现三者的同步操作,怎么做?这都是我们在实际应用中经常会遇到的问题,在VB中解决这个问题非常简单 , 可以通过Path属性的改变引发Change事件来实现 。例如:
Sub Dir1-Change()
File1.Path=Dir1.Path
End Sub
---- 该事件过程使窗体上的目录列表框Dir1和文件列表框File1产生同步 。因为目录列表框Path属性的改变将产生Change事件,所以在Dir1-Change事件过程中,把Dir1.Path赋给File1.Path,就可以产生同步效果 。类似地 , 增加下面的事件过程,就可以使三种列表框同步操作:
Sub Drive1-Change()
Dir1.Path=Drive1.Drive
End Sub
---- 该过程使驱动器列表框和目录列表框同步 , 前面的过程使目录列表框和文件列表框同步,从而使三种列表框同步,问题即可解决 。
vb.net2005 tcp聊天程序问题‘客户端向这样写vb.net局域网聊天气:在窗体说放两个文本框、两个标签、两个按钮、一个列表框
Imports System.Net
Imports System.Net.Sockets
Imports System.IO
Imports System.Threading
Public Class Form1
'网络基础数据流
Private ns As NetworkStream
Private swriter As StreamWriter
Private nsread As StreamReader
Private tcpclient As TcpClient
Private tcpconnected As Boolean = False
Private clisocket As Socket
Private mythread As Thread
'发送
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
If Me.TextBox2.Text"" Then
swriter.WriteLine(Me.TextBox2.Text)
swriter.Flush()
Me.TextBox2.Text = ""
Else
MessageBox.Show("发送信息不能为空vb.net局域网聊天气!", "错误提示")
End If
End Sub
Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)
If disposing Then
If Not (components Is Nothing) Then
components.Dispose()
End If
End If
MyBase.Dispose(disposing)
End Sub
'建立连连接
Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
Dim ipremote As IPAddress
Dim tcpclient As TcpClient
Try
ipremote = IPAddress.Parse(Me.TextBox1.Text)
Catch ex As Exception
MessageBox.Show("IP地址不合法!", "错误提示")
End Try
Try
tcpclient = New TcpClient(Me.TextBox1.Text, 8000)
ns = tcpclient.GetStream
swriter = New StreamWriter(ns)
Me.StatusBar1.Text = "已经连接上"
Me.Button2.Enabled = False
Me.Button1.Enabled = True
tcpconnected = True
Catch ex As Exception
MessageBox.Show("无法与远程8000端口建立连接!", "错误提示")
End Try
End Sub
Private Sub listen()
Try
Dim tcplistener As New TcpListener(IPAddress.Parse("127.0.0.1"), 8000)
tcplistener.Start()
tcpclient = tcplistener.AcceptTcpClient
ns = tcpclient.GetStream()
nsread = New StreamReader(ns)
While True
Dim msg As String = nsread.ReadLine
If msg = "stop" Then
tcplistener.Stop()
ns.Close()
nsread.Close()
mythread.Abort()
Else
Dim mytime As String = DateTime.Now.ToShortTimeString
Me.ListBox1.Items.Add(mytime""msg)
End If
End While
Catch ex As System.Security.SecurityException
MessageBox.Show("侦听失败!", "错误")
End Try
End Sub
End Class
VB.NET 如何实现局域网内即时会话楼主vb.net局域网聊天气你好,你所指vb.net局域网聊天气的那个指令就是"winchat",Windows自带的局域网聊天工具.使用方法:开始--运行--输入winchat,就可以打开Winchatvb.net局域网聊天气了.只能实现很简单的功能,并且是中文,没什么好介绍的,相信你一看就懂,希望可以帮到你!
ps:你所说的电影是杜拉拉升职记吧?貌似那是用的邮件发的,不小心点成群发vb.net局域网聊天气了~嘿嘿..
vb.net局域网聊天气的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于vbnet socket、vb.net局域网聊天气的信息别忘了在本站进行查找喔 。

    推荐阅读