开发网络应用的5个技巧

  • 来源: 互联网 作者: 若水   2008-03-17/16:11
  •  Visual Basic 6.0(以下简称VB 6)以其强大的功能为广大软件开发人员所喜爱,被用来开发各种应用程序。随着Internet的迅猛发展,VB 6在网络方面的应用开发也越来越多。本文介绍笔者在实际编程开发中总结的5个技巧,希望能为进行网络开发的朋友们提供一点参考。
    连通检测

          许多应用程序常常需要在程序中直接进行联网操作,以便进行一些必要的处理(如在线注册和在线帮助等),这就要求我们在程序中建立某些连接。很多软件在不知用户是否联网的情况下就启动浏览器查找网址,结果只能查出一错误网页,既浪费用户时间又没有任何效果。如果应用程序在查找网页之前能自动判断用户是否已经联网,就会节约许多时间,提高程序运行效率。

    下面是实现网络连通检测的VB 6代码:

    Private Sub Form_Load()

    If IsConnected = TRUE Then

    MsgBox (“您已经连通了Internet!”)

    End If

    If IsConnected = FALSE Then

    MsgBox (“您还没有连通 Internet!”)

    End If

    End Sub

    Option Explicit

    /*有关的API声明和定义*/

    Public Declare Function RasEnumConnections Lib “RasApi32.dll” Alias “RasEnumConnectionsA” (lpRasCon As Any, lpcb As Long, lpcConnections As Long) As Long

    Public Declare Function RasGetConnectStatus Lib “RasApi32.dll” Alias “RasGetConnectStatusA” (ByVal hRasCon As Long, lpStatus As Any) As Long

    /*常数和变量的设定*/

    Public Const RAS95_MaxEntryName = 256

    Public Const RAS95_MaxDeviceType = 16

    Public Const RAS95_MaxDeviceName = 32

    Public Type RASCONN95

    dwSize As Long

    hRasCon As Long

    szEntryName(RAS95_MaxEntryName) As Byte

    szDeviceType(RAS95_MaxDeviceType) As Byte

    szDeviceName(RAS95_MaxDeviceName) As Byte

    End Type

    Public Type RASCONNSTATUS95

    dwSize As Long

    RasConnState As Long

    dwError As Long

    szDeviceType(RAS95_MaxDeviceType) As Byte

    szDeviceName(RAS95_MaxDeviceName) As Byte

    End Type

    /*函数IsConnected返回连通的状态,如果为True则表示已连通*/

    Public Function IsConnected() As Boolean

    Dim TRasCon(255) As RASCONN95

    Dim lg As Long

    Dim lpcon As Long

    Dim RetVal As Long

    Dim Tstatus As RASCONNSTATUS95

    TRasCon(0).dwSize = 412

    lg = 256 * TRasCon(0).dwSize

    RetVal = RasEnumConnections(TRasCon(0), lg, lpcon)

    If RetVal <> 0 Then

    MsgBox “错误”

    Exit Function

    End If

    Tstatus.dwSize = 160

    RetVal = RasGetConnectStatus(TRasCon(0)

    .hRasCon,Tstatus)

    If Tstatus.RasConnState = &H2000 Then

    IsConnected = TRUE

    Else

    IsConnected = FALSE

    End If

    End Function

    启动拨号网络中的连接

    由于拨号网络不是一个可执行文件, 所以要启动拨号网络,需要借助 explorer.exe 。但若是要启动拨号网络中的某一个连接,则要借助rundll.exe 和 rnaui.dll两个文件。启动方法如下(假定此连接名称为163):

    Shell “rundll rnaui.dll,RnaDial 163”,vbNormalFocus

    上面假定了连接名称,但在实际编程中我们是不知道连接名称的。在窗体上放置一个命令按钮(cmdCallConnect),在其单击事件中进行连接处理。下面的代码介绍如何取得默认的连接名称并启动它:

    Option Explicit

    /*有关的API声明*/

    Private Declare Function RegOpenKeyEx Lib “advapi32” Alias “RegOpenKeyExA” (ByVal hKey As Long, ByVal lpSubKey As String, ByVal ulOptions As Long, ByVal samDesired As Long, phkResult As Long) As Long

    Private Declare Function RegQueryValueEx Lib “advapi32” Alias “RegQueryValueExA” (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, ByRef lpType As Long, ByVal szData As String, ByRef lpcbData As Long) As Long

    Private Declare Function RegCloseKey Lib “advapi32”(ByVal hKey As Long) As Long

    /*常数的设定*/

    Const HKEY_CURRENT_USER = &H80000001

    Const ERROR_SUCCESS = 0

    在命令按钮(cmdCallConnect)中加入如下代码:

    Private Sub cmdCallConnect_Click()

    /*启动默认拨号连接*/

    Shell “rundll rnaui.dll,RnaDial” + GetConnect, vbNormalFocus

    End Sub

    /*取得连接的函数(GetConnect)*/

    Public Function GetConnect() As String

    Dim hKey As Long

    Dim SubKey As String

    /*主键*/

    hKey = HKEY_CURRENT_USER

    /*子键*/

    SubKey = “RemoteAccess”

    /*取得默认连接名*/

    GetConnect=GetRegValue(hKey,SubKey, “Default”)

    End Function

    /*取得注册的函数(GetRegValue)*/

    Public Function GetRegValue(hKey As Long,lpszSubKey As String,szKey As String) As Variant

    On Error GoTo ErrorRoutineErr:

    Dim phkResult As Long

    Dim lResult As Long

    Dim szBuffer As String

    Dim lBuffSize As Long

    /*创建缓冲区*/

    szBuffer = Space(255)

    lBuffSize = Len(szBuffer)

    /*打开注册键*/

    RegOpenKeyEx hKey, lpszSubKey, 0, 1,phkResult #p#分页标题#e#

    /*取得查询结果*/

    lResult = RegQueryValueEx(phkResult, szKey, 0, 0, szBuffer, lBuffSize)

    /*关闭注册键*/

    RegCloseKey phkResult

    /*返回结果*/

    If lResult = ERROR_SUCCESS Then

    GetRegValue = Left(szBuffer, lBuffSize - 1)

    Else

    GetRegValue =“”

    End If

    Exit Function

    /*意外处理*/

    ErrorRoutineErr:

    GetRegValue =“”

    End Function

    设计E?mail的接收部分

    在VB 6菜单上点击“工程/部件...”,弹出“部件”对话框,在对话框的控件卡中选中Microsoft MAPI Controls 6.0控件,点击“确定”按钮后,工具箱上增加了MAPIMessage和MAPISession两个图标。

    在Form上加入一个MAPIMessage控件,取名为MAPIMessage1;再加入一个MAPISession控件,取名为MAPISession1;再加入三个TextBox控件,分别取名为Subject、Content和Indexno, 将它们的Caption分别改为邮件标题、邮件内容和邮件索引号;在TextBox前各加入一个Label控件,将Caption分别改为标题、内容和索引号。

    将MAPIMessage1的各项属性设置如下:

    DownLoadMail=TRUE;

    LogonUI=TRUE;

    NewSession=FALSE;

    UserName=“接收E?mail”。

    在Form上加入一个按钮(Getmail),将其Caption改为取邮件。

    在 Getmail_Click()事件中加入以下程序代码,程序的功能是使我们接收E?mail。

    MAPIMessage1.Fetch

    Form1.Caption=MAPIMessage1.MsgCount

    MAPIMessage1.MsgIndex=CINT(Indexno.text)

    Subject.Text = MAPIMessage1.MsgNoteText

    Content.Text = MAPIMessage1.MsgSubject

    其中Fetch命令用来将信件抓到系统存储器的inbuffer中。我们将信件抓回来后,可以通过MsgCount属性知道信件数量,接着可以用MsgIndex设置要看哪一封信件的内容、标题等。

    设计E?mail的发送部分

    1.参数设置

    进入Exchange系统,选择新增设置文件后屏幕上会显示所需要的信息服务,选择Internet Mail。

    把设置文件的名称设为test。屏幕会显示两个选项,您可以选择以Modem方式或以Network 方式连接。笔者所用的是Modem方式;假若您是使Internet专线,就要选择Network 方式。

    选择Modem方式后,Exchange会要求我们输入邮件服务器的IP地址。接着将Transform Message的模式设置为Automatic,这样当我们连接到邮件服务器时,新的信息会自动下载到本地端。接下来,将您所使用的E?mail地址、全名、口令和下载路径等一一设置好。

    2.程序设计

    在Form上加入一个MAPIMessage控件,取名为MAPIMessage1;加入一个MAPISession控件,取名为MAPISession1;并加入三个TextBox控件,取名为Subject、Content和Addr。并在三个TextBox前各加入一个Label,将Caption分别改为标题、内容和地址。

    将MAPIMessage1的各项属性设置如下:

    DownLoadMail=TRUE;

    LogonUI=TRUE;

    NewSession=FALSE;

    UserName=“发送E?mail”。

    这里将DownLoadMail设置为TRUE,当程序和邮件服务器第一次连接时,会将新的邮件下载到本地端。将LogonUI设置为TRUE,则当您程序中Logon名称输入错误时,系统会显示一个Message Box来让您输入正确的名称。

    由于这个程序仅使用一个Session,所以可将NewSession设置成FALSE。如果您有许多Session要建立的话,则将它设置成TRUE。UserName中所填的,是我们在Exchange中所新增的设置文件名称,如果没有填内容的话,系统将会显示一些Message Box请您输入文件。

    在Form上加入三个按钮,Logon、Logoff和Send,并分别将它们的Caption改为登录、离网和发送。

    在 Logon_Click()事件中加入以下程序代码,程序的功能是使我们登录到邮件服务器:

    MAPISession1.SignOn

    MAPIMessage1.SessionID=MAPISession1.SessionID


    评论 {{userinfo.comments}}

    {{money}}

    {{question.question}}

    A {{question.A}}
    B {{question.B}}
    C {{question.C}}
    D {{question.D}}
    提交

    驱动号 更多