Visual Basic 6.0(以下简称VB 6)以其强大的功能为广大软件开发人员所喜爱,被用来开发各种应用程序。随着Internet的迅猛发展,VB6在网络方面的应用开发也越来越多。本文介绍笔者在实际编程开发中总结的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
/*取得查询结果*/
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="接收Email"。
在Form上加入一个按钮(Getmail),将其Caption改为取邮件。
在 Getmail_Click()事件中加入以下程序代码,程序的功能是使我们接收Email。
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,这样当我们连接到邮件服务器时,新的信息会自动下载到本地端。接下来,将您所使用的Email地址、全名、口令和下载路径等一一设置好。
2.程序设计
在Form上加入一个MAPIMessage控件,取名为MAPIMessage1;加入一个MAPISession控件,取名为MAPISession1;并加入三个TextBox控件,取名为Subject、Content和Addr。并在三个TextBox前各加入一个Label,将Caption分别改为标题、内容和地址。
将MAPIMessage1的各项属性设置如下:
·DownLoadMail=TRUE;
·LogonUI=TRUE;
·NewSession=FALSE;
·UserName="发送Email"。
这里将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
sgBox "Your ID is" + Str
(MAPISession1.SessionID)
其中MAPISession1.SignOn是作登录的动作。在登录时,因为已经将MAPIMessage1控件的DownLoadMail属性设置为TRUE,所以可以在屏幕上看到Message Box,显示系统正在下载邮件。登录成功后,系统会传回一个SessionID,将该ID填入MAPIMessage1的SessionID中,这样就可以利用该Session来传送Email,同时用Message Box通知用户发送成功。
在Logoff_Click()事件中加入以下程序代码,程序的功能是使我们离开邮件服务器:
MAPIS1.SignOff
在Send_Click()事件中加入以下程序代码,程序的功能是使我们发送Email:
MAPIMessage1.Compose
MAPIMessage1.RecipDisplayName = Addr.text
MAPIMessage1.AddressResolveUI = TRUE
MAPIMessage1.MsgSubject = Subject.text
MAPIMessage1.MsgNoteText = Content.text
MAPIMessage1.Send
MsgBox "您发送成功啦!"
其中Compose命令的主要目的是使您可以改变RecipDisplayName的内容,将所需传送的Email地址、主题和文章内容分别填入 RecipDisplayName、MsgSubject和MsgNoteText,接着用Send命令发送出去。
访问Internet并调用Explorer
1.实现方法和控件介绍
首先在VB 6菜单上点击"工程/部件...",弹出"部件"对话框,在对话框的控件卡中选中Microsoft Internet Controls控件,点击"确定"按钮后工具箱上增加一个WebBrowser图标,将它加到Form中。
该控件有以下几个重要的方法和事件:
·GoHome:装入IE设定的起始页;
·Navigate:装入页面,如Object.Navigate url,其中url为URL地址,如http://www.microsoft.com;
·GoBack:返回上一个页面;
·GoForward:进入下一个页面;
·Stop:停止载入页面;
·BeforeNavigate Event:在每次装入页面前调用该事件;
·StatusTextChange Event:每次浏览器的操作状态改变时调用该事件。
2.具体的访问方法
将WebBrowser图标添加到Form中。并在Form上添加4个命令按钮,Name属性分别为:GoButton、BackButton、ForwardButton和StopButton,通过这4个命令按钮可以实现对浏览器的操作。在Form上添加一个TextBox控件,用来输入和显示当前的页面地址。在Form上添加一个Label控件,用来显示当前浏览器操作状态。
/*载入Form*/
Private Sub Form_Load()
/*程序装入后进入IE设定的起始页*/
WebBrowser1.GoHome
End Sub
/*改变Form尺寸*/
Private Sub Form_Resize()
/*改变窗口大小后同时改变控件的大小*/
WebBrowser1.Width = Form1.ScaleWidth
WebBrowser1.Height = Form1.ScaleHeight - 900
Label1.Width = Form1.ScaleWidth
Label1.Top = Form1.ScaleHeight - 300
End Sub
Private Sub BackButton_Click()
/*返回上一个页面*/
WebBrowser1.GoBack
End Sub
Private Sub ForwardButton_Click()
/*进入下一个页面*/
WebBrowser1.GoForward
End Sub
Private Sub GoButton_Click()
/*浏览输入的页面*/
WebBrowser1.Navigate (Text1.Text)
End Sub
Private Sub StopButton_Click()
/*停止浏览*/
WebBrowser1.Stop
End Sub
Private Sub Text1_KeyPress(KeyAscii As Integer)
/*输入地址后进行浏览*/
If KeyAscii = 13 Then
WebBrowser1.Navigate (Text1.Text)
End If
End Sub
Private Sub WebBrowser1_BeforeNavigate(ByVal URL As String, ByVal Flags As Long, ByVal TargetFrameName As String, PostData As Variant, ByVal Headers As String, Cancel As Boolean)
/*将当前显示的页面的URL地址显示在Text1上*/ Text1.Text = URL
End Sub
Private Sub WebBrowser1_StatusTextChange(ByVal Text As String)
/*Label1显示当前页面装入情况*/
Label1.Caption = Text
End Sub
分享到:
相关推荐
对VB网络编程有很大的帮助 喜欢VB编程的朋友们顶一下啊
VB网络编程非常不错,顶顶
在VB.NET中进行网络编程是开发跨平台应用程序和网络服务的关键技能。VB.NET(Visual Basic .NET)是Microsoft .NET框架的一部分,它提供了一系列强大的工具和类库,使得开发者能够轻松地创建网络应用。本指南将深入...
◆ 82.htm 用Sockets发送电子邮件 ◆ 83.htm 用VB 创 建 自 己 的 通 信 程 序 ◆ 84.htm 用VB5.0开发通信软件的技巧 ◆ 85.htm 用VB5开发IE ◆ 86.htm 用VB编写网络寻呼 ◆ 87.htm ...
《VB.NET网络编程指南》是一本专为VB.NET开发者设计的教程,主要涵盖了如何使用VB.NET进行网络通信和开发Web应用程序的关键技术。本指南通过一系列的htm格式文档,以图文并茂的方式阐述了网络编程的核心概念和实战...
《VB.NET网络编程指南》是一本深入探讨如何利用VB.NET进行网络编程的宝贵资源。VB.NET,全称Visual Basic .NET,是微软公司推出的面向对象的编程语言,它继承了Visual Basic的强大功能,并且与.NET Framework紧密...
**VB编程基础** 1. **语法结构**:VB使用类似于英语的语法,易于学习。它支持基本的数据类型,如Integer、Double、String等,以及变量声明、常量定义和数组。 2. **事件驱动编程**:VB的核心特点是事件驱动,程序...
在VB(Visual Basic)编程环境中,数据库访问是一个关键部分,尤其对于开发数据驱动的应用程序而言。本资源"VB数据库编程"深入浅出地探讨了如何使用VB与各种数据库进行交互,包括基本概念、API调用、连接管理以及...
《VB高级编程》是一本专为已经具备一定VB基础的编程人员设计的进阶学习资料。...这本书将引导你从基础走向精通,让你的VB编程技能更上一层楼。如果你已经有一定的VB基础,那么这本书无疑是你进一步提升的绝佳选择。
VB编程源代码 69监视网络联接VB编程源代码 69监视网络联接VB编程源代码 69监视网络联接VB编程源代码 69监视网络联接VB编程源代码 69监视网络联接VB编程源代码 69监视网络联接VB编程源代码 69监视网络联接VB编程源...
一个功能很强的综合了众多VB网络编程技巧集的程序源码,原型是一个用VB6.0写的网络工具箱程序,它可以实现以下功能:TCP/IP配置信息提娶Ping命令、端口侦听、网络流量监控、IP地址计算器、服务器时间同步、分段IP与...
资源名:VB精彩编程100个实例源代码 资源类型:程序源代码 源码说明: VB精彩编程100个源代码实例,实例很丰富,涉及的内容方方面面。有音量控制、拾色器、画图、抓屏、文本操作、获取操作系统信息、拖拉节点、查看...
【VB网络与远程控制编程】是编程领域的一个重要分支,主要涉及如何利用Visual Basic(VB)语言进行网络通信和实现远程控制功能。VB作为一种流行的编程工具,提供了丰富的库和API,使得开发者能够轻松构建网络应用和...
VB精彩编程200例VB精彩编程200例VB精彩编程200例VB精彩编程200例VB精彩编程200例VB精彩编程200例
本书以其结构清晰、重点突出的特点,深入浅出地讲解了VB编程的各种技巧和实用方法,旨在帮助读者拓展编程思维,提升编程能力。 在VB编程中,我们首先要理解的是VB的基本语法和编程环境。VB是一种基于事件驱动的编程...