请高手帮忙修正一个注册表模块!已经做成工程文件,有详细的实例的!

venyblue 2013-04-17 01:28:39
请高手帮忙修正一个注册表模块!已经做成工程文件,有详细的实例的!

模块是别人写的,本来就是支持中文有问题,我稍修改(也注释了),还是有问题!
想解决的问题是:
用模块创建的注册表键值等于实际的情况.
我希望RGetString(HKEY_LOCAL_MACHINE, "SOFTWARE\AAA", "VenySS")读取出来的数据等于永贤屏保.scr /S
也就是说,LenB(StrConv(RGetString(HKEY_LOCAL_MACHINE, "SOFTWARE\AAA", "VenySS"), vbFromUnicode)) = LenB(StrConv("永贤屏保.scr /S", vbFromUnicode)

先创建项和值,再进行相应测试,
测试完删除项和删除值就不留注册后的垃圾了.
应该不是很难,但是本人水平有限!请高手帮忙吧!http://66056.24286.84g.com/veny/vs/注册表模块.rar
...全文
547 点赞 收藏 32
写回复
32 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
是的,那部分改为RegOpenKey更好。
回复
venyblue 2013-09-06
问题算是解决了,结帖!
回复
venyblue 2013-09-01
引用 29 楼 myjian 的回复:
[quote=引用 28 楼 venyblue 的回复:] *另外,我在使用你的模块测试读取值时发现,会自动创建相应的项!而我的代码却仅仅是:
Text1.Text = RGetString("HKEY_LOCAL_MACHINE\SOFTWARE\AAA", "VenySS") 
你模块里用的是RegOpenKey打开键,我模块里用的是RegCreateKey,因此如果目标路径不存在,会创建.[/quote] 那么我认为把那部分改成RegOpenKey更好.
回复
引用 28 楼 venyblue 的回复:
*另外,我在使用你的模块测试读取值时发现,会自动创建相应的项!而我的代码却仅仅是:
Text1.Text = RGetString("HKEY_LOCAL_MACHINE\SOFTWARE\AAA", "VenySS") 
你模块里用的是RegOpenKey打开键,我模块里用的是RegCreateKey,因此如果目标路径不存在,会创建.
回复
venyblue 2013-08-14
引用 23 楼 myjian 的回复:
删除值删除项也完全正常.
我知道为什么你能清空了,因为你使用的不是XP系统,而我找的都是XP系统. 我用2003是可以清空的,把2003的注册表编辑器复制到XP上运行,也能清空. 现在,问题有点不同了: 所有的注册表模块代码创建的值("VenySS"="永贤屏保.scr /S"),使用XP的注册表编辑器都无法手工清空干净,那是代码问题还是XP的注册表编辑器的问题? XP的注册表编辑器的版本:5.1.2600.5512 2003的注册表编辑器的版本:5.2.3790.3959 *另外,我在使用你的模块测试读取值时发现,会自动创建相应的项!而我的代码却仅仅是:
Text1.Text = RGetString("HKEY_LOCAL_MACHINE\SOFTWARE\AAA", "VenySS") 
回复
stevejob 2013-08-04
楼上辛苦了,学习精神可嘉,身体固然重要,洗洗睡吧
回复
venyblue 2013-08-04
引用 23 楼 myjian 的回复:
删除值删除项也完全正常.
我用所有的(包括你的和我收集的很多个)注册表模块在多个使用不同光盘安装的XP系统和机器(包括虚拟机)都出现一样的问题: 手工清空值的数据的时候,不是真正清空!我希望的是清空"项"下的"值"的"数据",只清空数据. 那程序在那么多机器上运行,全部都不正常,我还是认为不是我的测试环境问题! 我已经重新上传文件,覆盖了原来的文件.你重新下载,看看. http://66056.24286.84g.com/veny/vs/注册表模块.rar 这次,我用原来的模块和你提供的模块做的两个工程,分别在两个文件夹. 使用我的模块测试时,要先创建项再创建值. 使用你的模块测试时,直接创建值就行. *另外,我在使用你的模块测试读取值时发现,会自动创建相应的项!而我的代码却仅仅是:
Text1.Text = RGetString("HKEY_LOCAL_MACHINE\SOFTWARE\AAA", "VenySS")
实现步骤你看20楼吧. 其中,步骤中的"在左边找到AAA,在右边找到VenySS,右键点击这个VenySS,选择修改(M),然后把永贤屏保.scr /S这些字删除,然后点击确定." 可以改成: 在左边找到AAA,在右边找到VenySS,双击这个VenySS,然后把永贤屏保.scr /S这些字删除,然后点击确定. 最后,你看看我提供的纯净XP的虚拟机的截图!
回复
venyblue 2013-08-04
引用 26 楼 myjian 的回复:
已下载最新的代码,结果与我22楼一模一样. 不过我觉得你可能还是会怀疑我,那我就录了两个动画上来,分别是虚拟机中的干净WIN2000以及真机WIN2003: 以上是WIN2000. 以上是WIN2003. 我已经技穷,再也帮不了你什么了,祝你好运:)
先感谢老马!老马是很热心,谢谢! 我知道为什么你能清空了,因为你使用的不是XP系统,而我找的都是XP系统. 我用2003是可以清空的,把2003的注册表编辑器复制到XP上运行,也能清空. 现在,问题有点不同了: 所有的注册表模块代码创建的值("VenySS"="永贤屏保.scr /S"),使用XP的注册表编辑器都无法手工清空干净,那是代码问题还是XP的注册表编辑器的问题? XP的注册表编辑器的版本:5.1.2600.5512 2003的注册表编辑器的版本:5.2.3790.3959 *另外,我在使用你的模块测试读取值时发现,会自动创建相应的项!而我的代码却仅仅是:
Text1.Text = RGetString("HKEY_LOCAL_MACHINE\SOFTWARE\AAA", "VenySS")
回复
已下载最新的代码,结果与我22楼一模一样.

不过我觉得你可能还是会怀疑我,那我就录了两个动画上来,分别是虚拟机中的干净WIN2000以及真机WIN2003:



以上是WIN2000.



以上是WIN2003.

我已经技穷,再也帮不了你什么了,祝你好运:)
回复
删除值删除项也完全正常.
回复
这下你真的该找你自己环境的问题了. 因为之前我头一次下载你代码时以为是你代码问题,都没有测试你的代码,就直接用我的模块上的. 而现在,我下载你的代码后直接创建项创建值,再比较,得出"相同". 然后再手工删除注册表项并导出,得到下面的内容:
Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\AAA]
"VenySS"=""

看来你的代码是木有问题的,问题在代码之外哦. 建议你装一个虚拟机. 另外,如果装了360,就关掉或卸载掉试试.
回复
引用 18 楼 venyblue 的回复:
[quote=引用 17 楼 myjian 的回复:] 我明白你所说的步骤,也是按照你说的做的. 程序创建注册表项,再手工用regedit删除项值,再在程序中读,对吧? 这在我这里一切正常,你应该考虑你机器的原因了. 下载个VBOX,在虚拟机里装个干净系统再试吧.
我试过别的机器了,也是一样,你手工删除的时候,打开注册表编辑器,在左边找到AAA,在右边找到VenySS,右键点击这个VenySS,选择修改(M),然后把永贤屏保.scr /S这些字删除,然后点击确定. 之后,你查看VenySS的数据(无论是否刷新),看看究竟是空的,还是还有东西?[/quote] 在我这里完全正常,为空.
回复
venyblue 2013-08-02
还有,要先创建值,就要先创建项,所以也要按一下那个程序的"创建项"的按钮!
回复
venyblue 2013-08-02
引用 19 楼 myjian 的回复:
在我这里完全正常,为空.
我在家的机器,在公司的机器,自己的笔记本,都是XP系统的,都不正常! 首先,你在我的那个程序里的点击"创建值"按钮,创建那个值. 然后,手工清空:运行regedit,打开注册表编辑器,在左边找到AAA,在右边找到VenySS,右键点击这个VenySS,选择修改(M),然后把永贤屏保.scr /S这些字删除,然后点击确定. 注意,只是清空VenySS的数据,不是删除VenySS. 未清空VenySS的数据时,导出的文件是:
Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\AAA]
"VenySS"="永贤屏保.scr /S"

清空VenySS的数据后,导出的文件是:
Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\AAA]
"VenySS"="氀"

实际希望清空VenySS的数据后,导出的文件是:
Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\AAA]
"VenySS"=""

回复
venyblue 2013-08-01
引用 17 楼 myjian 的回复:
我明白你所说的步骤,也是按照你说的做的. 程序创建注册表项,再手工用regedit删除项值,再在程序中读,对吧? 这在我这里一切正常,你应该考虑你机器的原因了. 下载个VBOX,在虚拟机里装个干净系统再试吧.
我试过别的机器了,也是一样,你手工删除的时候,打开注册表编辑器,在左边找到AAA,在右边找到VenySS,右键点击这个VenySS,选择修改(M),然后把永贤屏保.scr /S这些字删除,然后点击确定. 之后,你查看VenySS的数据(无论是否刷新),看看究竟是空的,还是还有东西?
回复
venyblue 2013-07-31
引用 15 楼 myjian 的回复:
别去纠结文件大小,编译选项里有执行速度优化与代码大小优化,选一下即可. 最后编译出来再用Aspack压一下,完全无压力. 如果功能实现不了,再小也白搭....不是么
也别说大小的问题,但是我用所有我能找到的模块,都有我遇到的问题: 无论是我提供的实例,还是你提供的模块做成的程序,创建出来的值都出现手工清空时,无法删除干净的问题! 以下以我提供实例为例,实现步骤: 1.使用RSetString()创建了串值,点击按钮创建就行.创建项,创建值. 2.打开注册表编辑器,手工清空该串值的数据"永贤屏保.scr /S",按确定.注意是手工删除,并非在程序删除. 3.结果,在未刷新的时候显示成"氀贤屏保.scr /S",而该串值的数据其实是"氀",并没有清空. 4.在此时,调试出现实时错误'5'在此句:RGetString = Left(lsKeyValue, InStr(lsKeyValue, Chr(0)) - 1),当然,如果创建的值能正常手工清空,这个错误就不会出现了! 你有些不明白的地方,我在14楼也回复过你: 你看第二步.2.打开注册表编辑器,手工清空该串值的数据"永贤屏保.scr /S",按确定.注意是手工删除,并非在程序删除. 意思是,打开Regedit.exe,依次来到HKEY_LOCAL_MACHINE\SOFTWARE\AAA,找到VenySS字符串,手工清空永贤屏保.scr /S,按确定,结果你看第三步.
回复
我明白你所说的步骤,也是按照你说的做的. 程序创建注册表项,再手工用regedit删除项值,再在程序中读,对吧? 这在我这里一切正常,你应该考虑你机器的原因了. 下载个VBOX,在虚拟机里装个干净系统再试吧.
回复
别去纠结文件大小,编译选项里有执行速度优化与代码大小优化,选一下即可. 最后编译出来再用Aspack压一下,完全无压力. 如果功能实现不了,再小也白搭....不是么
回复
venyblue 2013-07-30
引用 12 楼 myjian 的回复:
[quote=引用 11 楼 venyblue 的回复:] 3.结果,在未刷新的时候显示成"氀贤屏保.scr /S",而该串值的数据其实是"氀",并没有清空.
这是什么意思?哪里刷新?哪里显示成那个乱码? 另外你那个模块最好还是别用了,打开的句柄资源什么的全都没有释放,像是初学者写的.[/quote] 你看第二步.2.打开注册表编辑器,手工清空该串值的数据"永贤屏保.scr /S",按确定.注意是手工删除,并非在程序删除. 意思是,打开Regedit.exe,依次来到HKEY_LOCAL_MACHINE\SOFTWARE\AAA,找到VenySS字符串,手工清空永贤屏保.scr /S,按确定,结果你看第三步. 另外,我现在做的一个程序,用这个模块做出来的文件52K,用另外的几个模块都是56K的大小,因此选它.至于句柄资源释放问题,我自己也不懂...我希望模块的自定义函数全部都是实际的功能,你提供的那个除了实际功能外,还有一些是辅助性的自定义函数或过程,如:GetMainKeyHandle,ErrorMsg,ClearKK和ParseKey.我发另外一个我喜欢的模块给你看看,可是它做出来的文件比现在的大一点,所以我没有用它:
Attribute VB_Name = "Module1"
'模块代码声明
'==================================================
'注册表操作声明
Public Declare Function RegOpenKey Lib "advapi32.dll" Alias "RegOpenKeyA" (ByVal Hkey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
'Public Declare Function RegEnumValue Lib "advapi32.dll" Alias "RegEnumValueA" (ByVal Hkey As Long, ByVal dwIndex As Long, ByVal lpValueName As String, lpcbValueName As Long, ByVal lpReserved As Long, lpType As Long, lpData As Byte, lpcbData As Long) As Long
Public Declare Function RegCloseKey Lib "advapi32.dll" (ByVal Hkey As Long) As Long
Public Declare Function RegCreateKey Lib "advapi32.dll" Alias "RegCreateKeyA" (ByVal Hkey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
Public 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
'Public Declare Function RegEnumKeyEx Lib "advapi32.dll" Alias "RegEnumKeyExA" (ByVal Hkey As Long, ByVal dwIndex As Long, ByVal lpName As String, lpcbName As Long, ByVal lpReserved As Long, ByVal lpClass As String, lpcbClass As Long, lpftLastWriteTime As Any) As Long
Public 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
Public Declare Function RegDeleteValue Lib "advapi32.dll" Alias "RegDeleteValueA" (ByVal Hkey As Long, ByVal lpValueName As String) As Long
Public Declare Function RegDeleteKey Lib "advapi32.dll" Alias "RegDeleteKeyA" (ByVal Hkey As Long, ByVal lpSubKey As String) As Long

Public Const HKEY_CLASSES_ROOT = &H80000000
Public Const HKEY_CURRENT_USER = &H80000001
Public Const HKEY_LOCAL_MACHINE = &H80000002
Public Const HKEY_USERS = &H80000003
Public Const HKEY_PERFORMANCE_DATA = &H80000004
Public Const HKEY_CURRENT_CONFIG = &H80000005
Public Const HKEY_DYN_DATA = &H80000006
Private Const REG_SZ = 1&
Private Const REG_EXPAND_SZ = 2&
Private Const REG_BINARY = 3&
Private Const REG_DWORD = 4&
Private Const ERROR_SUCCESS = 0&
'==================================================

'================================
'注册表操作函数
'================================

'设置字符串值
Public Sub RSetString(Hkey As Long, strPath As String, strValue As String, strdata As String)
Dim keyhand As Long
RegCreateKey Hkey, strPath, keyhand
RegSetValueEx keyhand, strValue, 0, REG_SZ, ByVal strdata, LenB(StrConv(strdata, vbFromUnicode)) 'LenB(StrConv(strdata, vbFromUnicode))原本是Len(strdata),因为计算中文长度有误,所以改了
RegCloseKey keyhand
End Sub

'获取字符串值
Public Function RGetString(Hkey As Long, strPath As String, strValue As String)
Dim keyhand As Long
Dim lResult As Long
Dim strBuf As String
Dim lDataBufSize As Long
Dim intZeroPos As Integer
Dim lValueType As Long 'new add
RegOpenKey Hkey, strPath, keyhand
lResult = RegQueryValueEx(keyhand, strValue, 0&, lValueType, ByVal 0&, lDataBufSize)
If lValueType = REG_SZ Or lValueType = REG_EXPAND_SZ Then
strBuf = String(lDataBufSize, " ")
lResult = RegQueryValueEx(keyhand, strValue, 0&, lValueType, ByVal strBuf, lDataBufSize)
If lResult = ERROR_SUCCESS Then
intZeroPos = InStr(strBuf, Chr$(0))
If intZeroPos > 0 Then
RGetString = Left$(strBuf, intZeroPos - 1)
Else: RGetString = strBuf
End If
End If
End If
End Function

'设置DWORD值
Function RSetDword(ByVal Hkey As Long, ByVal strPath As String, ByVal strValueName As String, ByVal lData As Long)
Dim keyhand As Long
RegCreateKey Hkey, strPath, keyhand
RegSetValueEx keyhand, strValueName, 0&, REG_DWORD, lData, 4
RegCloseKey keyhand
End Function

'获取DWORD值
Function RGetDword(ByVal Hkey As Long, ByVal strPath As String, ByVal strValueName As String) As Long
Dim lResult As Long
Dim lValueType As Long
Dim lBuf As Long
Dim lDataBufSize As Long
Dim r As Long
Dim keyhand As Long
r = RegOpenKey(Hkey, strPath, keyhand)
'Get length/data type
lDataBufSize = 4
lResult = RegQueryValueEx(keyhand, strValueName, 0&, lValueType, lBuf, lDataBufSize)
If lResult = ERROR_SUCCESS Then
If lValueType = REG_DWORD Then
RGetDword = lBuf
End If
'Else
'Call errlog("RGetDword-" & strPath, False)
End If
r = RegCloseKey(keyhand)
End Function

'设置二进制值
Function RSetBinary(ByVal Hkey As Long, ByVal strPath As String, ByVal strValueName As String, ByVal lData As Long, ByVal BitNumber As Long)
Dim keyhand As Long
RegCreateKey Hkey, strPath, keyhand
RegSetValueEx keyhand, strValueName, 0&, REG_BINARY, lData, BitNumber
RegCloseKey keyhand
End Function

'获取二进制值
Function RGetBinary(ByVal Hkey As Long, ByVal strPath As String, ByVal strValueName As String) As Long
Dim lResult As Long
Dim lValueType As Long
Dim lBuf As Long
Dim lDataBufSize As Long
Dim r As Long
Dim keyhand As Long
r = RegOpenKey(Hkey, strPath, keyhand)
'Get length/data type
lDataBufSize = 4
lResult = RegQueryValueEx(keyhand, strValueName, 0&, lValueType, lBuf, lDataBufSize)
If lResult = ERROR_SUCCESS Then
If lValueType = REG_BINARY Then
RGetBinary = lBuf
End If
End If
r = RegCloseKey(keyhand)
End Function

'删除键值
Public Function RDeleteValue(ByVal Hkey As Long, ByVal strPath As String, ByVal strValue As String)
Dim keyhand As Long
RegOpenKey Hkey, strPath, keyhand
RegDeleteValue keyhand, strValue
RegCloseKey keyhand
End Function

'创建主键
Public Function RCreateKey(ByVal Hkey As Long, ByVal strKey As String)
Dim keyhand&
RegCreateKey Hkey, strKey, keyhand
RegCloseKey keyhand&
End Function

'删除主键
Public Function RDeleteKey(ByVal Hkey As Long, ByVal strKey As String)
RegDeleteKey Hkey, strKey
End Function
回复
我刚试了,用这句添加注册表值:
SetStringValue "HKEY_LOCAL_MACHINE\SOFTWARE\AAA", "VenySS", "永贤屏保.scr /S"
再手工把VenySS里的字符串删空后,用下面语句读值:
msgbox GetStringValue("HKEY_LOCAL_MACHINE\SOFTWARE\AAA", "VenySS")
一切正常.
回复
加载更多回复
相关推荐
发帖
VB基础类
创建于2007-09-28

7489

社区成员

VB 基础类
申请成为版主
帖子事件
创建了帖子
2013-04-17 01:28
社区公告
暂无公告