当前位置: 网学 > 编程文档 > VB > 正文

如何用VB编写网络寻呼

来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 12/10/16
下载{$ArticleTitle}原创论文样式

作者:岳兵

提起ICQ的大名,爱好电脑的朋友一定不会感到陌生的吧?ICQ就是互联网上的寻呼机,无论什么时候,只要你的朋友在线,你只需在ICQ中输入他的ID号码,你就可以在互联网上呼到他。ICQ由于其方便、快捷,且拥有众多的注册用户而一举成为互联网上最流行的网络寻呼机,它几乎成为每一个上网用户的必备之物。当你在使用ICQ的时候,是否会想过自己动手编写一个网络寻呼机呢?这其实在vb中就可以实现。
  网络寻呼的原理就是当客户端程序连接服务器时,通过服务器搜索所要呼叫的ID号码,如果检测到此用户且该用户正处于联网状态,则服务器通知此用户的客户端程序响应主叫方客户端程序,然后在主叫方和被叫方建立连接后,双方就可以聊天或进行其它的通信。
  在VB中编写网络寻呼机需要建立两个程序,一个为客户端程序Client,一个为服务器端程序Server。

  一、在Client工程中建立一个窗体,加载WinSock控件,称为tcpClient,协议选择TCP。再加入四个文本框,用以输入服务器的IP地址、服务器端口号,被呼叫的网络寻呼ID号以及用户登录ID号。然后再在窗体中加入三个按钮,分别命名为“连接”、“断开”和“退出”,点击“连接”按钮,并进行如下初始化连接,代码如下:

 Private Sub Command1_Click()
  If Len(Text1.Text) = 0 And Len(Text2.Text) = 0 Then
   MsgBox ("请输入主机名或主机IP地址。")
   Exit Sub
  ElseIf Len(Text1.Text) > 0 Then
   tcpClient.RemoteHost = Text1.Text
   tcpClient.RemotePort = Text2.Text
  End If
  tcpClient.Connect
  Timer1.Enabled = True
 End Sub

 Private Sub Command2_Click()
  tcpClient.Close   ''断开连接
 End Sub

 Private Sub Command3_Click()
  End
 End Sub

 Private Sub Form_Load()
  Text2.Text = "1001"
 End Sub

 Private Sub tcpClient_Connect()
  tcpClient.SendData (Text3.Text&"@"&Text4.Text)
 End Sub

 Private Sub tcpClient_DataArrival(ByVal bytesTotal As Long)
  Dim strData As String
  tcpClient.GetData strData
  strData = strData + "呼叫"
  ''在收到呼叫消息后弹出一对话框并显示主叫方ID号码
  MsgBox (strData)
 End Sub

  二、在服务器端Server工程中也建立一个窗体,加载WinSock控件,称为tcpServer,协议选择TCP,设置其Index值为0,并在工程中添加模块。

  内容如下:

 Private Type ActiveUser
  ClientIP As String ''记录客户的IP地址
  ClientPort As Integer ''记录当前会话的端口
  ClientID As Long ''记录客户的ID号码
  ClientConnected As Boolean ''客户连接状态,True表示已连接,False表示没有连接
 End Type
 Dim CurUser() As ActiveUser
 Dim tcpIndex As Integer ''跟踪当前建立连接数

  在Form_Load事件中加入如下代码:

 Private Sub Form_Load()
  tcpServer(0).Protocol = sckTCPProtocol
  tcpServer(0).LocalPort = 1001 ''将 LocalPort 属性设置为一个整数。
  tcpServer(0).Listen ''然后调用 Listen 方法。
  tcpIndex = 1
 End Sub

  准备应答客户端程序的请求连接,使用ConnectionRequest事件来应答户端程序的请求,代码如下:


 Private Sub tcpServer_ConnectionRequest (Index As Integer, ByVal requestID As Long)
  Dim i As Integer
  On Error GoTo ErrHandle
  For i = 1 To tcpIndex ''选择一个空闲端口
   If CurUser(i).ClientConnected = False And i <> tcpIndex Then
    Load tc
  • 上一篇资讯: 用VB获取桌面图象
  • 下一篇资讯: 用VB开发即时战略游戏
  • 网学推荐

    免费论文

    原创论文

    浏览:
    设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
    版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
    湘ICP备09003080号