错误语句是tcpClient.SendData txtSend.Text按说明应该是未成功连接便使用sendData引起的错误,但为什么客户端和服务端一起关掉,之后再一起启动就不会出错,而只关掉客户端再启动(服务端一直开着),然后再连接服务端,接着发言,就出现以上错误?????跟这个一样,是在MSDN中的要创建一个 TCP 服务器,请按照以下步骤执行: 创建新的 Standard EXE 工程。
将缺省窗体的名称改为 frmServer。
将窗体的标题改为“TCP 服务器”。
在窗体中放入一个 Winsock 控件,并将它的名字改为 tcpServer。
在窗体上添加两个 TextBox 控件。将第一个命名为 txtSendData,第二个为 txtOutput。
为窗体添加如下的代码。
Private Sub Form_Load()
'将 LocalPort 属性设置为一个整数。
'然后调用 Listen 方法。
tcpServer.LocalPort = 1001
tcpServer.Listen
frmClient.Show '显示客户端的窗体。
End SubPrivate Sub tcpServer_ConnectionRequest _
(ByVal requestID As Long)
'检查控件的 State 属性是否为关闭的。
'如果不是,
'在接受新的连接之前先关闭此连接。
If tcpServer.State <> sckClosed Then _
tcpServer.Close
'接受具有 requestID 参数的
'连接。
tcpServer.Accept requestID
End SubPrivate Sub txtSendData_Change()
'名为 txtSendData 的 TextBox 控件中
'包含了要发送的数据。当用户往文本框中
'键入数据时,使用 SendData 方法
'发送输入的字符串。
tcpServer.SendData txtSendData.Text
End SubPrivate 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 SubPrivate Sub cmdConnect_Click()
'调用 Connect 方法,初始化连接。
tcpClient.Connect
End SubPrivate Sub txtSendData_Change()
tcpClient.SendData txtSend.Text
End SubPrivate Sub tcpClient_DataArrival _
(ByVal bytesTotal As Long)
Dim strData As String
tcpClient.GetData strData
txtOutput.Text = strData
End Sub
将缺省窗体的名称改为 frmServer。
将窗体的标题改为“TCP 服务器”。
在窗体中放入一个 Winsock 控件,并将它的名字改为 tcpServer。
在窗体上添加两个 TextBox 控件。将第一个命名为 txtSendData,第二个为 txtOutput。
为窗体添加如下的代码。
Private Sub Form_Load()
'将 LocalPort 属性设置为一个整数。
'然后调用 Listen 方法。
tcpServer.LocalPort = 1001
tcpServer.Listen
frmClient.Show '显示客户端的窗体。
End SubPrivate Sub tcpServer_ConnectionRequest _
(ByVal requestID As Long)
'检查控件的 State 属性是否为关闭的。
'如果不是,
'在接受新的连接之前先关闭此连接。
If tcpServer.State <> sckClosed Then _
tcpServer.Close
'接受具有 requestID 参数的
'连接。
tcpServer.Accept requestID
End SubPrivate Sub txtSendData_Change()
'名为 txtSendData 的 TextBox 控件中
'包含了要发送的数据。当用户往文本框中
'键入数据时,使用 SendData 方法
'发送输入的字符串。
tcpServer.SendData txtSendData.Text
End SubPrivate 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 SubPrivate Sub cmdConnect_Click()
'调用 Connect 方法,初始化连接。
tcpClient.Connect
End SubPrivate Sub txtSendData_Change()
tcpClient.SendData txtSend.Text
End SubPrivate Sub tcpClient_DataArrival _
(ByVal bytesTotal As Long)
Dim strData As String
tcpClient.GetData strData
txtOutput.Text = strData
End Sub
解决方案 »
- 文件内存映射后,不能删除的问题?
- 如何获得WebBrowser中文本框的文本内容呢?
- 如何用adodc控件获取当前显示记录的编号?
- 请教怎样在VB中按行列输出数据?
- 关于数据库的问题,请帮忙
- vb能否用api函数直接结束内存中某一进程!?
- 关于环境变量的问题
- 【vb】知道某个用户,怎么获取这个用户的权限值呢?
- 请问那位大哥知道在数据库里存放一般的文章、规章制度(pdf)、表格内容、图片和附加的说明、动画、flash时,格式上有什么区别?
- 关于用ExitWindowsEx执行“注销”操作
- 主 题:定时操作
- 谁知道如何调用记事本的打印设置这个功能??????紧急.我是老山啊..可以加到600分.....
客户端退出前先通知一下服务端。发一个退出通知给服务端(如QUIT)
服务端接到(QUIT)后关闭客户端的连接,然后再侦听就可以了。
客户端在close事件中end.
这是我的做法。
可能方法有点不好,但即行得通
进行出错处理,Private Sub Winsock1_Error(ByVal Number As Integer, Description As String, ByVal Scode As Long, ByVal Source As String, ByVal HelpFile As String, ByVal HelpContext As Long, CancelDisplay As Boolean)End Sub
Winsockclient
text1------------(连接的主机名或IP地址)
Textsend---------(发送的内容,按回车发送)
Textget------------(接收内容)
Command2---------(连接主机)
Command1---------(退出)Private Sub Command1_Click()
Winsockclient.SendData "end"
End SubPrivate Sub Command2_Click()
Winsockclient.RemoteHost = Text1.Text
Winsockclient.Connect
End SubPrivate Sub Form_Load()
Textsend.Visible = False
Textget.Visible = False
Winsockclient.RemotePort = 1979
Winsockclient.RemoteHost = " "
End Sub
Private Sub Textsend_KeyPress(KeyAscii As Integer)
If KeyAscii = 13 Then
Winsockclient.SendData Textsend.Text
End If
End SubPrivate Sub Winsockclient_Close()
Winsockclient.Close
End
End SubPrivate Sub winsockclient_Connect()
Textsend.Visible = True
Textget.Visible = True
Command2.Visible = False
End SubPrivate Sub winsockclient_DataArrival(ByVal bytesTotal As Long)
Dim tmpstr As String
Winsockclient.GetData tmpstr
Textget.Text = tmpstr
End Sub
服务端:在窗体上加四个控件
Winsockserver
textsend---------(发送的内容)
textget-----------(接收内容)
Command1---------(退出)Private Sub Command1_Click()
End
End SubPrivate Sub Form_Load()
textsend.Visible = False
textget.Visible = False
Winsockserver.LocalPort = 1979
Winsockserver.Listen
End SubPrivate Sub textsend_Change()
Winsockserver.SendData textsend.Text
End SubPrivate Sub Winsockserver_Close()
Winsockserver.Close
End
End SubPrivate Sub Winsockserver_ConnectionRequest(ByVal requestID As Long)
textsend.Visible = True
textget.Visible = True
If Winsockserver.State <> sckClosed Then Winsockserver.Close
Winsockserver.Accept requestID
End SubPrivate Sub Winsockserver_DataArrival(ByVal bytesTotal As Long)
Dim tmpstr As String
Winsockserver.GetData tmpstr
If tmpstr = "end" Then
Winsockserver.Close
Winsockserver.LocalPort = 1979
Winsockserver.Listen
Else
textget.Text = tmpstr
End If
End Sub以上代码生成执行文件后
先运行服务端,然后运行客户端
在客户端text1上输入本机名称(即计算机名称)按command2即可测试。