赛迪网 > IT技术 编程语言 > 文章
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

用VB编写网络寻呼机(2)

发布时间:2006.08.16 03:08     来源:plwww    作者:

 

二、在服务器端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 = Left(s, i - 1) ’把号存入mKey

RequID = Right(s, Len(s) - i) ’ID存入RequID

End If


’如果是请求寻呼某一ID号码,则检索当前此ID用户是否登录(即CurUser数组中是否存在此用户),然后发送信息,通知此用户响应呼叫并显示主叫用户ID号码。

For i = 1 To tcpIndex

If RequID = CurUser(i).ClientID And CurUser(i)

.ClientConnected = True Then

tcpServer(i).SendData (SearhID)

End If

Next

Exit Sub

ErrHandle:

If Err.Number = sckBadState Then ’连接不正确

CurUser(i).ClientConnected = False

CurUser(i).ClientIP = ""

Unload tcpServer(i)

Resume Next

End If

End Sub


本程序仅提供了用Visual Basic 编写网络寻呼的思路和主要部分的实现过程,至于主叫方和被叫方建立连接后的通信并未扩展,读者若有兴趣,可在这方面加入具体的实现代码,就可以给本程序增加更多的功能,如实时聊天,语音对话等。如果在服务器程序检索到被叫方时,分别通知两者客户端程序,使主叫方和被叫方直接利用IP地址进行连接,则两者的连接速度将会有大幅度的提高。

 


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 自己的IE——用VB制作浏览器 (09-07) · 基于Winsock 的小型网络管理系统及其实现 (01-28)
· 怎样手工声明API (03-10) · 如何在IE右键菜单中添加菜单项以及如何添加IE (11-21)
· 用VB设计能适应各种显示属性的界面 (03-10) · 表达式编译计算器(下) (12-07)
· VB调用API函数使窗口保持在最上层 (01-17) · 常见问题:文本框控件的消息及应用 (04-24)
· 用VB编写一个弹出菜单类 (06-16) · vb开发通信软件 (03-27)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
[政务][电信][金融][农业][制造业][中小企业]
[CIO][ERP][协同][IT管理][中间件][电子商务]
[政策][地方][专家][评估][辞典][博客][社区]
· 专题:一路畅通构想曲——让出行不再遭遇堵车
· CIO工作亲历:企业ERP选型不能忽视"选人关"
· 综述:信息化建设给中国监狱带来的各种变化
· 金融业风险管理和法规遵从有五点需考虑的因素
· 保险业CIO关注:该如何建立统一高效的CRM体系
· 调查显示:多数CIO对IT规划仍存在困惑和误解
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管