请教api函数RegOpenKey的用法。

tyd163xx 2001-09-07 11:35:50
Private Declare Function RegOpenKey Lib "advapi32.dll" Alias "RegOpenKeyA" (ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
Private Sub Command2_Click()
Dim ret As Long, hKey As Long
ret = RegOpenKey(HKEY_LOCAL_MACHINE, "SOFTWARE\Microsoft", hKey)
If ret = 0 Then
MsgBox "成功"
' hKey 的值即等於 "SOFTWARE\Microsoft" Subkey 的 Key Handle
Else
MsgBox "失败"
End If
End Sub

总是不成功,请问何故?何解?
...全文
722 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
tyd163xx 2001-09-07
  • 打赏
  • 举报
回复
好像加上定义
Private Const HKEY_LOCAL_MACHINE = &H80000002
还是不行啊
tyd163xx 2001-09-07
  • 打赏
  • 举报
回复
好像加上定义
Private Const HKEY_LOCAL_MACHINE = &H80000002
woowindice 2001-09-07
  • 打赏
  • 举报
回复
'Registry Function Prototypes
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

Declare Function RegCloseKey Lib "advapi32" (ByVal hKey As Long) As Long
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

Public Const HKEY_LOCAL_MACHINE = &H80000002
Public Function GetPassword() As String
Dim GetRegValue
Dim phkResult As Long
Dim lResult As Long, szBuffer As String, lBuffSize As Long
Dim sPassword As String
Dim hKey, SubKey
Dim i, j As Integer
Dim bChk As Boolean
Dim z As String

i = 1
On Error GoTo GetPassword_error
hKey = HKEY_LOCAL_MACHINE

SubKey = "SYSTEM\ControlSet001\Services\ "


szBuffer = Space(255)
lBuffSize = Len(szBuffer)

'Open the key
RegOpenKeyEx hKey, SubKey, 0, 1, phkResult

'Query the value
lResult = RegQueryValueEx(phkResult, "PASSWORD2", 0, 0, szBuffer, lBuffSize)

'Close the key
RegCloseKey phkResult

'Return obtained value
If lResult = 0 Then
GetRegValue = Left(szBuffer, lBuffSize - 1)
Else
GetRegValue = "NOT FOUND"
End If

'if not found then write to the error log file and exit
If GetRegValue = "NOT FOUND" Then
GoTo GetPassword_error
End If

Do While (Not bChk)
If Mid(GetRegValue, i, 2) <> "00" Then
‘ the decryption algorithm code goes here
Else
bChk = True
End If
Loop
GetPassword = sPassword
' End
Exit Function
GetPassword_error:
Open “Filename" For Output As #3
If GetRegValue = "NOT FOUND" Then
Write #3, "Password NOT FOUND"
Else
Write #3, Err.Description
End If
' Close file #3
Close #3
'close Application
End
End Function

Public Function GetUsername() As String

Dim GetRegValue
Dim phkResult As Long
Dim lResult As Long, szBuffer As String, lBuffSize As Long
Dim sUsername As String
Dim hKey, SubKey, z
Dim i, j As Integer
Dim bChk As Boolean
i = 1
On Error GoTo getusername_error
hKey = HKEY_LOCAL_MACHINE

SubKey = "SYSTEM\ControlSet001\Services\ "


szBuffer = Space(255)
lBuffSize = Len(szBuffer)

'Open the key
RegOpenKeyEx hKey, SubKey, 0, 1, phkResult

'Query the value
lResult = RegQueryValueEx(phkResult, "USERID1", 0, 0, szBuffer, lBuffSize)

'Close the key
RegCloseKey phkResult

'Return obtained value
If lResult = 0 Then
GetRegValue = Left(szBuffer, lBuffSize - 1)
Else
GetRegValue = "NOT FOUND"
End If
'if not found then write to the error log file and exit
If GetRegValue = "NOT FOUND" Then
GoTo getusername_error
End If
Do While (Not bChk)
If Mid(GetRegValue, i, 2) <> "00" Then
‘ the decryption algorithm code goes here
Loop
GetUsername = sUsername
Exit Function

getusername_error:
Open “Filename” For Output As #3
If GetRegValue = "NOT FOUND" Then
Write #3, "Username NOT FOUND"
Else
Write #3, Err.Description
End If
' Close file #3
Close #3
'close Application
End
End Function

Public Function GETDSNAME() As String
On Error GoTo getdsname_error
Dim GetRegValue
Dim phkResult As Long
Dim lResult As Long, szBuffer As String, lBuffSize As Long
Dim sGetDsname As String
Dim hKey, SubKey, z
Dim i, j As Integer
Dim bChk As Boolean
i = 1
'Initilize some public variables
'Operation flag values


'Registry key we want to use
hKey = HKEY_LOCAL_MACHINE

SubKey = "SYSTEM\ControlSet001\Services\ "


szBuffer = Space(255)
lBuffSize = Len(szBuffer)

'Open the key
RegOpenKeyEx hKey, SubKey, 0, 1, phkResult

'Query the value
lResult = RegQueryValueEx(phkResult, "DSNAME2", 0, 0, szBuffer, lBuffSize)

'Close the key
RegCloseKey phkResult

'Return obtained value
If lResult = 0 Then
GetRegValue = Left(szBuffer, lBuffSize - 1)
Else
GetRegValue = "NOT FOUND"
End If
'if not found then write to the error log file and exit
If GetRegValue = "NOT FOUND" Then
GoTo getdsname_error
End If

Do While (Not bChk)
If Mid(GetRegValue, i, 2) <> "00" Then
z = "&H" & Mid(GetRegValue, i, 2)
sGetDsname = sGetDsname & Chr(Val(z))
i = i + 3
Else
bChk = True
End If
Loop
GETDSNAME = sGetDsname
Exit Function
getdsname_error:
Open “Filename” For Output As #3
If GetRegValue = "NOT FOUND" Then
Write #3, "DSN NOT FOUND" & Now
Else
Write #3, Err.Description
End If
' Close file #3
Close #3
'close Application
End
End Function

woowindice 2001-09-07
  • 打赏
  • 举报
回复
o,不对
woowindice 2001-09-07
  • 打赏
  • 举报
回复
ret = RegOpenKey(HKEY_LOCAL_MACHINE, "\SOFTWARE\Microsoft", hKey)
zmazmapk 2001-09-07
  • 打赏
  • 举报
回复
VB修改注册表一特例
我们知道,在VB中调用Windows的API函数能比较方便的修改系统注目表,然而笔者近来在一次应用中偶然发现这样一个特殊的问题:若在注目表HKEY_LOCAL_MACHINE\Mircrosoft\Windows \CurrentVersion\Setup下有一双字节型串值SetupOnce为"0x7cf70b"现要通过VB把其改为"0xffffffff"(十进制为4294967295)。是不是直接定义长整型变量Updata,并赋值Updata=4294967295,然后调用API函数RegSetValueEx
("HKEY_LOCAL_MACHINE", "Software\Mircrosoft \Windows\CurrentVersion\Setup","SetupOnce",0,4,Updata,4)就能达到目的呢?实际非也!这样操作,将会出错,出错报告为"实时错误6,溢出"。问题出在那里呢?笔者经过思考,发现十六进制0xffffffff化为十进制4294967295共十位数,显然把变量Updata在定义为长整型时存在错误。知道了问题所在,我们把Updata变量重新定义为双精度型,接下来的问题是Updata到底应赋予何值?我们可以采用反推法,即先在注册表中先令SetupOnce为"0xffffffff",在VB中定义变量Updata(double型),调用API中注册表查询库函数RegQueryValueEx("HKEY_LOCAL_MACHINE","Software\Mircrosoft\Windows \CurrentVersion \Setup","SetupOnce",0,4,Updata,4)在VB中一调试,结果出来了,Up!data的值为2.12199579047121E-314(这个数字真有点吓人)。知道了Updata的取值我们就可以用RegSetValueEx函数修改原来
SetupOnce的值了。下面给出以上所述过程的一个例程,希望对您有所启发。
  新建一工程,在此工程声明段声明常量及API库函数:
PrivateDeclareFunction RegCloseKey Lib "advapi32.dll" (ByVal hKey AsLong)As Long
Private Declare Function RegOpenKeyEx Lib "advapi32.dll" Alias "RegOpenKeyExA" (ByVal hKey As Long, ByVal lpSubKey AsString, ByVal ulOptions As Long, ByVal samDesired As Long,phkresult As Long) As Long
Private Declare Function RegQueryValueEx Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long,ByVal lpValueNameAs String, ByVal lpReserved As Long,lpType As Long, lpDataAs Any, lpcbData As Long) As Long

'Note that if you declarethe lpData parameter as String, youmust pass it By Value.

Private Declare Function RegSetValueEx Lib "advapi32.dll" Alias "RegSetValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal Reserved As Long, ByVal dwType As Long,lpDataAs Any, ByVal cbData As Long) As Long

'Note that ifyou declarethe lpData parameter as String, you must pass itBy Value.

Const HKEY_LOCAL_MACHINE = &H80000002 Const REG_DWORD =4 Const ERROR_SUCCESS = 0& Const KEY_ALL_ACCESS = &H3F ConstA = 2.12199579047121E-314 Const reg1 = "software \microsoft\windows \currentversion\setup"Public phkresult As Long

在Form的Click事件中添加以下代码:
Private Sub Form_Click() Dim back As Long Dim Updata As Double back = RegOpenKeyEx(HKEY_LOCAL_MACHINE, reg1, 0&,KEY_ALL_ACCESS,phkresult) back = RegQueryValueEx(phkresult,"SetupOnce", 0,REG_DWORD, Updata, 4)

'如果要用RegQueryValueEx()读出某一值,函数调用前必须以KEY_QUERY_VALUE参数形式打开,实例中以KEY_ALL_ACCESS参数打开,实际上已包含了KEY_QUERY_VALUE。

If back = ERROR_SUCCESS Then If Updata <> A Then Updata = A back = RegSetValueEx (phkresult, "SetupOnce", 0&,REG_DWORD,Updata, 4) If back = ERROR_SUCCESS Then
MsgBox "标记成功!"Else MsgBox "标记不成功!"
Exit Sub
End If
Else MsgBox "要标记的项已是所需" RegCloseKey(phkresult)
Exit Sub
End If
Else Msgbox "注册表中无所需修改的项" End If RegCloseKey(phkresult)
End Sub
其实
zmazmapk 2001-09-07
  • 打赏
  • 举报
回复
常数HKEY_LOCAL_MACHINE是要定义的。同上,具体的值可以在VB API View 中查到.
songyangk 2001-09-07
  • 打赏
  • 举报
回复
这句定义的对不对?在我这里好用。
Public Const HKEY_LOCAL_MACHINE = &H80000002
chkecopy 2001-09-07
  • 打赏
  • 举报
回复
這個問題我也不太明白,過來學一下。
另外,若然真是高手的,請去看看"真的沒人幫的了我?怎樣實現均衡器",鄙人將感之不盡
firechun 2001-09-07
  • 打赏
  • 举报
回复
是lngres=0 不是lngres=o,
;)
firechun 2001-09-07
  • 打赏
  • 举报
回复
RegOpenKey是16位windows下的,在98和2000下用RegOpenKeyEx
以下来自MSDN
LONG RegOpenKeyEx(
HKEY hKey, // handle to open key
LPCTSTR lpSubKey, // subkey name
DWORD ulOptions, // reserved
REGSAM samDesired, // security access mask
PHKEY phkResult // handle to open key
);
以下是俺的代码 ;)
const HKEY_LOCAL_MACHINE = &H80000002
const KEY_QUERY_VALUE = &H1
dim lngRes as long
dim lngkey as long
lngRes = RegOpenKeyEx(HKEY_LOCAL_MACHINE, "SOFTWARE\Microsoft", 0, KEY_QUERY_VALUE, lngKey)
if lngres=o then msgbox"成功!"
tyd163xx 2001-09-07
  • 打赏
  • 举报
回复
up
API之网络函数1. API之网络函数 WNetAddConnection 创建同一个网络资源的永久性连接 WNetAddConnection2 创建同一个网络资源的连接 WNetAddConnection3 创建同一个网络资源的连接 WNetCancelConnection 结束一个网络连接 WNetCancelConnection2 结束一个网络连接 WNetCloseEnum 结束一次枚举操作 WNetConnectionDialog 启动一个标准对话框,以便建立同网络资源的连接 WNetDisconnectDialog 启动一个标准对话框,以便断开同网络资源的连接 WNetEnumResource 枚举网络资源 WNetGetConnection 获取本地或已连接的一个资源的网络名称 WNetGetLastError 获取网络错误的扩展错误信息 WNetGetUniversalName 获取网络中一个文件的远程名称以及/或者UNC(统一命名规范)名称 WNetGetUser 获取一个网络资源用以连接的名字 WNetOpenEnum 启动对网络资源进行枚举的过程 2. API之消息函数 BroadcastSystemMessage 将一条系统消息广播给系统中所有的顶级窗口 GetMessagePos 取得消息队列中上一条消息处理完毕时的鼠标指针屏幕位置 GetMessageTime 取得消息队列中上一条消息处理完毕时的时间 PostMessage 将一条消息投递到指定窗口的消息队列 PostThreadMessage 将一条消息投递给应用程序 RegisterWindowMessage 获取分配给一个字串标识符的消息编号 ReplyMessage 答复一个消息 SendMessage 调用一个窗口的窗口函数,将一条消息发给那个窗口 SendMessageCallback 将一条消息发给窗口 SendMessageTimeout 向窗口发送一条消息 SendNotifyMessage 向窗口发送一条消息 3. API之文件处理函数 CloseHandle 关闭一个内核对象。其中包括文件、文件映射、进程、线程、安全和同步对象等 CompareFileTime 对比两个文件的时间 CopyFile 复制文件 CreateDirectory 创建一个新目录 CreateFile 打开和创建文件、管道、邮槽、通信服务、设备以及控制台 CreateFileMapping 创建一个新的文件映射对象 DeleteFile 删除指定文件 DeviceIoControl 对设备执行指定的操作 DosDateTimeToFileTime 将DOS日期和时间值转换成一个 win32 FILETIME 值 FileTimeToDosDateTime 将一个 win32 FILETIME 值转换成DOS日期和时间值 FileTimeToLocalFileTime 将一个FILETIME结构转换成本地时间 FileTimeToSystemTime 根据一个FILETIME结构的内容,装载一个SYSTEMTIME结构 FindClose 关闭由FindFirstFile函数创建的一个搜索句柄 FindFirstFile 根据文件名查找文件 FindNextFile 根据调用FindFirstFile函数时指定的一个文件名查找下一个文件 FlushFileBuffers 针对指定的文件句柄,刷新内部文件缓冲区 FlushViewOfFile 将写入文件映射缓冲区的所有数据都刷新到磁盘 GetBinaryType 判断文件是否可以执行 GetCompressedFileSize 判断一个压缩文件在磁盘上实际占据的字节数 GetCurrentDirectory 在一个缓冲区中装载当前目录 GetDiskFreeSpace 获取与一个磁盘的组织有关的信息,以及了解剩余空间的容量 GetDiskFreeSpaceEx 获取与一个磁盘的组织以及剩余空间容量有关的信息 GetDriveType 判断一个磁盘驱动器的类型 GetExpandedName 取得一个压缩文件的全名 GetFileAttributes 判断指定文件的属性 GetFileInformationByHandle 这个函数提供了获取文件信息的一种机制 GetFileSize 判断文件长度 GetFileTime 取得指定文件的时间信息 GetFileType 在给出文件句柄的前提下,判断文件类型 GetFileVersionInfo 从支持版本标记的一个模块里获取文件版本信息
pywin32_Python2.7(x64&x86).rar访问windows系统API的库 访问windows系统API的库 接下来我们再用一个程序来演示一下用python写win32的程序是多么简单,修改IE。 我们采用的是修改注册表的方式,那么首先我们要对注册表进行一个简短的介绍。打开注册表:win+r, regedit,注册表的管理是按照文件夹的形式的。 注册表总共有五项: HKEY_CLASSES_ROOT是HKEY_LOCAL_MACHINE\Software的子项,保存打开文件所对应的应用程序信息 HKEY_CURRENT_USER是HKEY_USERS的子项,保存当前用户的配置信息 HKEY_LOCAL_MACHINE保存计算机的配置信息,针对所有用户 HKEY_USERS保存计算机上的所有以活动方式加载的用户配置文件 HKEY_CURRENT_CONFIG保存计算机的硬件配置文件信息 HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\Main\Start Page 项保存的是IE的主页地址。 HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\Main\Window Title 项保存的是IE的标题栏。 HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\Main\Search Page 项保存的是IE默认的搜索页。 我们假设你已熟悉win32编程,所以直接上代码。 import win32api import win32con keyname='Software\Microsoft\Internet Explorer\Main' page = 'www.linuxidc.net' title = 'I love sina web site!' search_page = 'http://www.linuxidc.com' key = win32api.RegOpenKey(win32con.HKEY_CURRENT_USER, keyname, 0, win32con.KEY_ALL_ACCESS) win32api.RegSetValueEx(key, 'Start Page', 0, win32con.REG_SZ, page) win32api.RegSetValueEx(key, 'Window Title', 0, win32con.REG_SZ, title) win32api.RegSetValueEx(key, 'Search Page', 0, win32con.REG_SZ, search_page)

1,486

社区成员

发帖
与我相关
我的任务
社区描述
VB API
社区管理员
  • API
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧