中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Visual Basic > 网络
在VB中实现客户端程序自动查找并连接服务端程序
作者:netmuse 时间:2001-11-03 10:47 出处:互联网 责编:chinaitpower
              摘要:在VB中实现客户端程序自动查找并连接服务端程序
在VB中实现客户端程序自动查找并连接服务端程序
               (南京审计学院教育技术中心 210029  丁国勇)
在一般的讲解WINSOCK控件的用法的文章中,无论是使用TCP还是UDP,客户端程序连接服务端程序时无一例外的要指定IP地址(或机器名)和端口号,那么,在端口已知而服务端程序所在机器地址或名称未知的情况下,怎样实现客户端程序发起并建立连接呢,笔者在实际编程中遇到了这种情况,并使用如下方法解决了这个问题。
这种方法巧妙的将 TCP与UDP结合起来,概括起来就是UDP查找,TCP连接。
对于客户端程序,使用了三个WINSOCK 控件:
1 sockclient   协议sckTcpprotocol 用于向服务端程序发起TCP连接
2 socklink     协议sckUdpprotocol 用于向本网广播地址发送数据
3 sockgetdata  协议sckUdpprotocol 用于接受从服务端程序返回的信息
定义一个String类型全局变量 MeIp,用于存放本机的IP地址。
在Form_load()事件中,编写如下程序:
Dim netbcaddress As String
MeIp = socklink.LocalIP     获得本机IP地址
netmask存放本网的广播地址,
设IP地址为192.168.100.215,子网掩码为255.255.255.0
该网的广播地址即为192.168.100.255,从本机IP地址怎样得到
广播地址请读者自己考虑。
sockgetdata.Bind "9400"  ' 定到本地端口9400
socklink.RemoteHost = netmask   '本网广播地址发送信息,内容是本机的IP地址
socklink.RemotePort = 9401
socklink.SendData "dgy.." & MeIp
在sockgetdata的DataArrival里这样定义
Private Sub sockgetdata_DataArrival(ByVal bytesTotal As Long)
Dim StrData As String
sockgetdata.GetData StrData  '得数据,数据为服务端程序所在机器的IP地址
If Trim(StrData) <> "" Then
sockclient.RemoteHost = StrData  '户端程序与服务端程序建立连接。
sockclient.RemotePort = 8092
sockclient.Connect
End If
End Sub
在服务端程序中,则要从广播地址获得客户端的IP地址,并将自己的IP地址发送到客户端,让客户
端与自己建立连接.
服务端程序中,同样也用到如下三个winsock控件:
1 sockserver控件数组  协议sckTcpprotocol 用于接受客户端的TCP连接
2 sockgetdata   协议sckUdpprotocol  用于从广播地址获得客户端的IP地址
3 sockudpsend   协议sckUdpprotocol  用于向客户端发送服务端程序的IP地址
在Form_load()中
sockgetdata.Bind "9401"  '9401端口侦听
定义如下结构和函数用于分离数据
Option Explicit
Private Type UdpData
    ok As Boolean
    IP As String
End Type
Private Function UdpDataSwitch(UdpData As String) As UdpData
Dim p As String
Dim MyStrs As Variant
Dim strs As Variant
p = ""
MyStrs = Split(UdpData, "..")
For Each strs In MyStrs
    If p = "dgy" Then
        UdpDataSwitch.ok = True
        UdpDataSwitch.IP = strs
        Exit Function
    End If
    p = strs
Next
UdpDataSwitch.ok = False
UdpDataSwitch.IP = ""
End Function
在sockgetdata的DataArrival事件中
Private Sub sockgetdata_DataArrival(ByVal bytesTotal As Long)
DoEvents
Dim DataArrival As String
Dim CanSend As Boolean
Dim Cip As String
sockudplink.GetData DataArrival
CanSend = UdpDataSwitch(DataArrival).ok
If CanSend = True Then
    sockudpsend.RemoteHost = UdpDataSwitch(DataArrival).IP
    sockudpsend.RemotePort =9400
    sockudpsend.SendData sockudpsend.LocalIP
    End If
End Sub
至于sockserver 怎样响应sockclient 的连接请求,看一般的介绍winsock编程的文章就可以
得到答案。
这样,就能完成在端口已知而服务端程序所在机器地址或名称未知的情况下,巧妙使用UDP和TCP,完成客户端程序与服务端程序的连接。
关于在VB中怎样得到本机所在网络的广播地址(特别是在动态获得IP地址的情况下),欢迎大家来信与我探讨   netmuse@njai.edu.cn
 
关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有