频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

启动拨号网络中的连接

来源: 作者: 出处:巧巧读书 2006-11-04 进入讨论组

  启动拨号网络中的连接

  由于拨号网络不是一个可执行文件, 所以要启动拨号网络,需要借助 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文章地址: http://www.qqread.com/vb/q271056.html 更多文章 更多内容请看网络管理实用手册网络故障手册网络组网专题专题,或进入讨论组讨论。
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
最新论坛文章
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章