VB修改注册表一特例
作者:吴伟军 来源:未知 添加时间:2006-5-21 15:47:45新建一工程,在此工程声明段声明常量及API库函数:
Private Declare Function RegCloseKey Lib "advapi32.dll" (ByVal hKey As Long) As Long
Private Declare Function RegOpenKeyEx Lib "advapi32.dll" 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.dll" Alias "RegQueryValueExA" (ByVal hKey As Long,ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, lpData As Any, lpcbData As Long) As Long ' Note that if you declare the lpData parameter as String, you must 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, lpData As Any, ByVal cbData As Long) As Long ' Note that if you declare the lpData parameter as String, you must pass it By Value.
Const HKEY_LOCAL_MACHINE = &H80000002
Const REG_DWORD = 4
Const ERROR_SUCCESS = 0&
Const KEY_ALL_ACCESS = &H3F
Const A = 2.12199579047121E-314
Const reg1 = "softwaremicrosoftwindowscurrentversionsetup"
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
其实,以上例程完全可以用做加密技术。国内某个带"霸"字的软件亦采用了类似的加密技术,当然,只是在加密的表现结果上表现而已。
以上代码在VB6.0及VB5.0中调试通过。
站内搜索