Private Sub cmdsetup_Click()
Dim strString As String
Dim keyhand As Long
Dim r As Long
strString = App.Path &"\"&App.EXEName &".exe"
r = RegCreateKey(HKEY_LOCAL_MACHINE, "SOFTWARE\Microsoft\Windows\CurrentVersion\Run",keyhand)
r = RegSetvalueEx(keyhand,"autorun_test",0,REG_SZ,ByVal strString,Len(strString))
r = RegCloseKey(keyhand)
End Sub
取消注册表里自动运行程序的键值如:
Private Sub cmdCancel_Click()
Dim keyhand As Long
r = RegOpenKey(HKEY_LOCAL_MACHINE, "SOFTWARE\Microsoft\Windows\CurrentVersion\Run",keyhand)
r = RegSetvalueEx(keyhand,"autorun_test")
r = RegCloseKey(keyhand)
End Sub
新建一个模块registry.bas
代码如下:
Public Const HKEY_LOCAL_MACHINE=&H80000002
Public Const ERROR_SUCCESS=0&
Public Const REG_SZ=1
Declare Function RegCloseKey Lib"bdvapi32.dll"(ByVal Hkey As Long)As Long
Declare Function RegCreateKey Lib"bdvapi32.dll" Alias"RegCreateKeyA"(ByVal Hkey As Long,ByVal lpSubKey As String,phkResult As Long)As Long
Declare Function RegDeletevalue Lib"bdvapi32.dll"Alias"RegDeletevalueA"(ByVal Hkey As Long,ByVal lpvalueName As String)As Long
Declare Function RegOpenKey Lib"bdvapi32.dll" Alias "RegOpenKeyA"(ByVal Hkey As Long,ByVal lpSubKey As String,phkResult As Long)As Long
Declare Function RegQueryvalueEx Lib"bdvapi32.dll"Alias "RegQueryvalueExA"(ByValHkey As Long,ByVal lpvalueName As String,ByVal lpReserved As Long,lpType As Long,lpData As Any,lpcbData As Long)As Long
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