设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 2919|回复: 0
打印 上一主题 下一主题

用VB编写网络寻呼机

[复制链接]
跳转到指定楼层
1#
发表于 2002-10-29 23:31:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
提起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 tcpServer(i)
tcpServer(i).LocalPort = CurUser(i).ClientPort - 1
           tcpServer(i).Accept requestID
           Exit For
ElseIf CurUser(i).ClientConnected = False Then
            Load tcpServer(i)
            tcpServer(i).LocalPort = Port
If tcpServer(i).State < > sckClosed Then
                tcpServer(i).Close
            End If
            tcpServer(i).Accept requestID
           Exit For
        End If
    Next
    DoEvents
    '测试连接是否成功
    If tcpServer(i).State = sckConnected Then
        If i = tcpIndex Then     
        '已经没有可用端口,记录客户的IP地址和端口号
            tcpIndex = tcpIndex + 1
            Port = Port + 1
            ReDim Preserve CurUser(tcpIndex)
   CurUser(i).ClientIP = tcpServer(i).RemoteHostIP
   CurUser(i).ClientConnected = True
   CurUser(i).ClientPort = Port
   CurUser(tcpIndex).ClientConnected = False
   Else
   CurUser(i).ClientIP = tcpServer(i).RemoteHostIP
   CurUser(i).ClientPort = Port
  CurUser(i).ClientConnected = True
        End If
    End If
    Exit Sub
ErrHandle:
    Resume Next  
    '检查控件的 State 属性,如未关闭,在接受新的连接之
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-4-29 02:47 , Processed in 0.082588 second(s), 24 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表