用Winsock制作一套聊天室和对话系统
2008-02-23 06:57:30来源:互联网 阅读 ()
一·Winsock的主要属性、事件和方法
Winsock是不可见控件,控件文件名是MSWINSCK.OCX,全称为Mcirosoft winsock control,使用时要将此控件调入工具箱。
1·属性:①Protocol=0 //使用TCP协议;
②RemoteHost //准备连接远程机的IP地址
③RemotePort //连接远程机的IP端口号 (1024—65535之间)
④LocalPort //本地机监听IP端口号必须与呼叫机端口号相同
2·方法:①connect //申请连接远程机
②listen //设置监听
③accept //建立实际连接
④senddata //发送数据
⑤getdata //接收数据
⑥close //关闭连接
3·事件:①connectionrequest //一方请求连接时另一方产生
②connect //一方机接受连接时另一方产生
③close //一方机关闭连接时另一方产生
④dataArrival //一方发送数据另一方产生
⑤error //请求连接失败时产生
二·制作方法
⑴ 在一工程中添加两个表单form1(模拟客户端)、form2(模拟服务器端)。
form1中装入控件:
控件名
主要属性
用 途
VB.Form form1
caption=”雷萌聊天室”
controlbox=0 ‘False
模拟客户机表单
VB.Textbox text1
multiline=-1 ‘True
scrollbars=3 ‘Bath
用于输入发往聊天室的信息
VB.Textbox text2
locked=-1 ‘True
multiline=-1 ‘True
scrollbars=3 ‘Bath
显示从聊天室发来的信息
VB.Combobox combo1
text=”10.84.234.11” ‘任定默认地址
放入常用的地址
VB.Commandbutton comm1
caption=”退出”
最小化form1
VB.Commandbutton comm2
caption=”连接”
请求与输入的地址连接
VB.Commandbutton send
caption=”发送”
发送Text1中的内容
VB.Label label1
caption=“请在此输入发表的信息”
Text1的框标
VB.Label label2
caption=“聊天室或对方的信息”
Text2的框标
VB.Label label3
caption=”等待连接”
显示连接状态信息
VB.Label label4
caption=”聊天室或对方地址”
用于指示Combo1
VB.Label label5
caption=”操作:选地址连接,连接成功看到聊天室内容后再输信息发送”
操作说明
VB.Timer timer1
interval=6000; enabled=false
防止连接超时
MSWinsocklib.winsock a
用于数据传输
form2中装入控件:
控件名
主要属性
用 途
VB.Form form2
caption=”接收信息”
controlbox=0 ‘False
模拟客户机表单
VB.Commandbutton command1
caption=”返回”
隐含Form2窗口
VB.Commandbutton command2
caption=”对话”
点对点会话时用此直接启动Form1
VB.Textbox text1
locked=-1 ‘True
multiline=-1 ‘True
scrollbars=3 ‘Bath
存放聊天或对话内容
VB.Label label1
caption=”接收的信息”
Text1的框标
MSWinsocklib.Winsock a
用于监听
MSWinsocklib.Winsock b
用于传送聊天信息
⑵ 在Form1的各控件事件中加入如下代码:
Dim flag As Boolean 注释:连接状态变量
Private Sub a_Connect()
flag = True
End Sub
Private Sub a_DataArrival(ByVal bytesTotal As Long)
Dim i As String
a.GetData i
Label3.Caption = "连接成功!"
Comm2.MousePointer = 0
Form1.MousePointer = 0
Timer1.Enabled = False
If i = Chr(0) Then
Text2.Text = "你是今天第一个进入本聊天室的客户。" Chr(13) Chr(10)
Else
Text2.Text = Text2.Text i
End If
Text2.SelStart = Len(Text2.Text)
Send.MousePointer = 0
Combo1.Enabled = False
Comm2.Caption = "断开连接"
Text1.SetFocus
End Sub
Private Sub a_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)
flag = False
Timer1.Enabled = False
Comm2.MousePointer = 0
Form1.MousePointer = 0
MsgBox "网络连接失败 !"
Label3.Caption = "等待连接"
Combo1.Enabled = True
Combo1.SetFocus
a.Close
Comm2.Caption = "连接"
End Sub
Private Sub Comm1_Click()
a.Close 注释:关闭连接
Form1.Windowstate = 1
End Sub
Private Sub Comm2_Click()
If Comm2.Caption = "断开连接" Then
a.Close
Comm2.Caption = "连接"
Label3.Caption = "等待连接"
Combo1.Enabled = True
Timer1.Enabled = False
Comm2.MousePointer = 0
Form1.MousePointer = 0
Else
Text2.Text = ""
Label3.Caption = "正在连接.."
Comm2.MousePointer = 11
Form1.MousePointer = 11
Timer1.Enabled = True
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:自动更新工作站的应用程序
下一篇:制作VB另类按钮
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash