vbscript Registry 注册表操作实现代码(读写删除)
发布时间:2016-12-03 18:43:44 所属栏目:Asp教程 来源:站长网
导读:VBScript Code: 复制代码 代码如下: ' Create a WSH Shell object: Set wshShell = CreateObject( "WScript.Shell" ) ' ' Create a new key: wshShell.RegWrite "HKCUTestKey", "" ' Create a new DWORD value: wshShell.RegWrite "HKCUTestKeyDWordTes
VBScript Code: 复制代码 代码如下: ' Create a WSH Shell object: Set wshShell = CreateObject( "WScript.Shell" ) ' ' Create a new key: wshShell.RegWrite "HKCUTestKey", "" ' Create a new DWORD value: wshShell.RegWrite "HKCUTestKeyDWordTestValue", 1, "REG_DWORD" ' Create a new subkey and a string value in that new subkey: wshShell.RegWrite "HKCUTestKeySubKeyStringTestValue", "Test", "REG_SZ" ' Read the values we just created: WScript.Echo "HKCUTestKeyDWordTestValue = " _ wshShell.RegRead( "HKCUTestKeyDWordTestValue" ) WScript.Echo "HKCUTestKeySubKeyStringTestValue = """ _ wshShell.RegRead( "HKCUTestKeySubKeyStringTestValue" ) """" ' Delete the subkey and key and the values they contain: wshShell.RegDelete "HKCUTestKeySubKey" wshShell.RegDelete "HKCUTestKey" ' Note: Since the WSH Shell has no Enumeration functionality, you cannot ' use the WSH Shell object to delete an entire "tree" unless you ' know the exact name of every subkey. ' If you don't, use the WMI StdRegProv instead. ' Release the object Set wshShell = Nothing 用VBScript编写的WSH程序文件的扩展名为.vbs,该脚本程序在窗口界面是由wscript.exe文件解释执行的,在字符界面是由cscript.exe文件解释执行的,命令格式为:cscript filename.vbs 创建对象 用VBScript修改注册表,必须先创建一个能于操作系统沟通的对象,再利用该对象的各种方法对注册表进行操作,创建这个对象的方法和格式如下: Dim OperationReGIStry Set OperationRegistry=WScript.CreateObject("WScript.Shell") 上述这些代码就创建了一个能与操作系统沟通的对象OperationRegistry 对象的方法 有了以上这个对象,并不等于就能马上对注册表进行操作,我们还必须弄清该对象对注册表进行操作的几种重要方法. 1.对注册表的读操作RegRead 2.对注册表的写操作RegWrite 3.对注册表的删操作RegDelete 补充一点,WSH还有两个通用的方法: WScript.Echo()用来显示一串文本信息,相当于VB中的MsgBox()。 Wscript.Quit()用来退出VBScript程序。 方法的参数 对于以上三种操作RegRead,RegWrite,RegDelete都需要带参数进行,并且这些操作的参数的个数和形式又不尽相同,下面我就把它们的一个共同且必不可少的参数讲一下: 该参数可称作是"路径参数",它包括根键,主键路径和键值,各部分表示的方法如下: 根键: 根键有两种表示方法。 方法一:直接用它在注册表中的字符串来表示,如: HKEY_CLASSES_ROOT,HKEY_CURRENT_USER等 方法二:用缩写的四个字母来表示,前两个为HK,后两个即为根键单词的首字母。如: 根键HKEY_CLASSES_ROOT表示为:HKCR, 根键HKEY_CURRENT_USER可表示为:HKCU等。 主键路径: 主键路径就是目标键在注册表中的主键位置,各个主键之间用""符分隔开。如:"SoftwareMicrosoftWindowsCurrentVersionPolicies" 键值: 键值参数直接接在主键路径之后。例如一个完整的路径如下所示: "HKCRSoftwareMicrosoftWindowsCurrentVersionPoliciesNoRun" 方法详解 1、RegRead操作详解 读操作RegRead主要是用来读取注册表中主键的默认值或键值的数据,我们可以将读得的数据送到相应的变量中,再利用VB中的MsgBox()函数将该数据显示出来,这就达到了读取注册表中数据的目的(也可以利用对象OperationRegistry的方法Popup()将读取的数据送至屏幕), 例如: 复制代码 代码如下: 'read.vbs(将以下代码存为read.vbs文件) Dim OperationRegistry Set OperationRegistry=WScript.CreateObject("WScript.Shell") Dim Read_Data1,Read_Data2 Read_Data1=OperationRegistry.RegRead("HKCR.xxf") '读取根键HKEY_CLASSES_ROOT之下的.xxf主键的默认值,并将该数据送至变量Read_Data1 Read_Data2=OperationRegistry.RegRead("HKCR.xxfvalue") '读取.xxf主键之下的value键值的数据,并将该数据送至变量Read_Data2 MsgBox("Default="Read_Data1" value="Read_Data2) '将读取的数据显示出来 2、RegWrite操作详解 写操作RegWrite主要是用来在注册表中新建主键或键值,并要赋予给它们一个初始值,该操作同样可以对注册表中以存在的主键或键值进行数据的修改,因此写操作的参数结构就比读操作要复杂一些,它不仅要路径参数,还要一个初始值和类型参数. 先来看初始值参数,该参数对于写操作来说是必不可少的,它可以为空(null)但却不能省掉。在新建主键时,初始值参数就赋给了该主键的默认值,在新建键值时,初始值参数就成了新建键值的初始数据.而初始值的类型,则是由类型参数决定的.类型主要有以下三种: (1)REG_SZ:字符型.该类型为缺省类型 (2)REG_DWORD:双字节型. (3)REG_BINARY:二进制型. 以上三种类型第1种和第2种用得最多,第3种类型在某些场合可以用第2种加以替代,这三种类型的赋值方法如下: 对于REG_SZ型:直接用字符串赋予,如"text","string"等 对于REG_DWORD型和REG_BINARY型则有两种赋值方式 i)直接用十进制的数表示,如:0,1等. ii)用十六进制的数表示,如:0x12,0xff等. 看例: 复制代码 代码如下: 'write.VBs Dim OperationReGIStry Set OperationRegistry=WScript.CreateObject("WScript.Shell") Default=OperationRegistry.RegRead("HKCR") '获取一个空值 (null) OperationRegistry.RegWrite "HKCR.xxf",Default '在根键HKEY_CLASSES_ROOT之下新建主键.xxf,并置其默认值为空 OperationRegistry.RegWrite "HKCR.xxf","xxffile" '在根键HKEY_CLASSES_ROOT之下新建主键.xxf,并置其默认值?quot;xxffile" OperationRegistry.RegWrite "HKCR.xxfvalue1","string" '在主键.xxf之下新建一个字符串型键值value1,并置其初始值为"string" OperationRegistry.RegWrite "HKCR.xxfvalue2",1,"REG_DWORD" '在主键.xxf之下新建一个REG_DWORD型键值value2,并置其初始值为1 OperationRegistry.RegWrite "HKCR.xxfvalue3",0Xff,"REG_BINARY" '在主键.xxf之下新建一个二进制型键值value3,并置其初始值为十六进制的ff 3、RegDelete操作详解 删除操作RegDelete主要是用来删除注册表中已存在的主键或键值,该操作是一种极其危险的操作,它能将主键或键值毫不留情的在注册表中“砍掉”,无论该键值下面有多重要的数据,它都能畅行无阻,因此在使用该操作时务必小心。 删除操作的参数形式与读操作的参数形式几乎完全相同,只是有一点小小的区别,那就是删除操作不需要将操作的返回值送给某一变量,例如: 复制代码 代码如下: 'delete.vbs Dim OperationRegistry Set OperationRegistry=WScript.CreateObject("WScript.Shell") OperationRegistry.RegRead("HKCR.xxfvalue") '删除.xxf主键之下的value键值 OperationRegistry.RegRead("HKCR.xxf") '删除根键HKEY_CLASSES_ROOT之下的.xxf主键 强调一点,不要更改注册表中已存在的主键或键值,更不要将它们删除,因为对注册表进行了不当的写操作或删操作,情况严重的会导致系统崩溃!如果你真想这么做,那就请你作好注册表的备份。 应用实例 1、读本机“计算机名” 复制代码 代码如下: 'ReadComputerName.vbs Dim ReadComputerName Set ReadComputerName=WScript.CreateObject("WScript.Shell") Dim ComputerName,RegPath RegPath="HKLMSystemCurrentControlSetControl ComputerNameComputerNameComputerName" ComputerName=ReadComputerName.RegRead(RegPath) MsgBox("计算机名为"ComputerName) 2、隐藏快捷方式图标上的小箭头 复制代码 代码如下: 'Hidden.vbs Dim HiddenArrowIcon Set HiddenArrowIcon=WScript.CreateObject("WScript.Shell") Dim RegPath1,RegPath2 RegPath1="HKCRlnkfileIsShortCut" RegPath2="HKCRpiffileIsShortCut" HiddenArrowIcon.RegDelete(RegPath1) HiddenArrowIcon.RegDelete(RegPath2) 3、改造“开始”菜单 复制代码 代码如下: 'ChangeStartMenu.vbs Dim ChangeStartMenu Set ChangeStartMenu=WScript.CreateObject("WScript.Shell") RegPath="HKCRSoftwareMicrosoftWindowsCurrentVersionPolicies" Type_Name="REG_DWORD" Key_Data=1 StartMenu_Run="NoRun" StartMenu_Find="NoFind" StartMenu_Close="NoClose" Sub Change(Argument) ChangeStartMenu.RegWrite RegPathArgument,Key_Data,Type_Name MsgBox("Success!") End Sub Call Change(StartMenu_Run) '禁用“开始”菜单中的“运行”功能 Call Change(StartMenu_Find) '禁用“开始”菜单中的“查找”功能 Call Change(StartMenu_Close) '禁用“开始”菜单中的“关闭系统”功能 4、向Windows中添加自启动程序 该程序能在开机时自动运行。 复制代码 代码如下: 'AddAutoRunProgram.vbs '假设该程序在c:myfile文件夹中,文件名为autorun.exe Dim AutoRunProgram Set AutoRunProgram=WScript.CreateObject("WScript.Shell") RegPath="HKLMSoftwareMicrosoftWindowsCurrentVersionRun" Type_Name="REG_SZ" Key_Name="AutoRun" Key_Data="C:Myfileautorun.exe" '该自启动程序的全路径文件名 AutoRunProgram.Write RegPathKey_Name,Key_Data,Type_Name '在启动组中添加自启动程序autorun.exe MsgBox("Success!") (编辑:淮北站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |