手机站
网通分站
电信主站
密 码:
用户名:
当前位置 : 主页>网络编程>Asp.Net编程>列表

编写网络寻呼机

来源:互联网 作者:西部数码 时间:2008-04-09
西部数码-全国虚拟主机10强!40余项虚拟主机管理功能,全国领先!双线多线虚拟主机南北访问畅通无阻!免费赠送企业邮局,.CN域名,自助建站480元起,免费试用7天,满意再付款! P4主机租用799元/月.月付免压金!
  提起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 属性,如未关闭,在接受新的连接之前关闭此连接。
  If tcpServer(0).State <> sckClosed Then
  tcpServer(0).Close
  tcpServer(0).Accept requestID  
  '接受具有 requestID 参数的,连接。
End Sub

Private Sub tcpServer_DataArrival(Index As Integer, ByVal bytesTotal As Long)
 Dim i As Integer
 Dim s As String
 Dim RequID As Long  '主叫方ID号码
 Dim SearchID As Long '被叫方ID号码

 On Error GoTo ErrHandle
 tcpServer(Index).GetData s, vbString
 '接收数据并存入s  
 If Mid(s, i, 1) = "@" Then 
  '分离s中的主叫方和被叫方ID号码
  SearhID =

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

热点关注
IDC资讯 虚拟主机 域名注册 托管租用 vps主机 智能建站
网站运营 建站经验 策划盈利 搜索优化 网站推广 免费资源
网站联盟 联盟新闻 联盟介绍 联盟点评 网赚技巧
行业资讯 业界动态 搜索引擎 网络游戏 门户动态 电子商务 广告传媒
网络编程 Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术 Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷 Internet Explorer
网页制作 FrontPages Dreamweaver Javascript css photoshop fireworks Flash
程序设计 Java技术 C/C++ VB delphi
网络知识 网络协议 网络安全 网络管理 组网方案 Cisco技术
操作系统 Win2000 WinXP Win2003 Mac OS Linux FreeBSD
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 价格总览 | 资讯中心 | 友情链接 | 网站地图 | 招贤纳士 | RSS