足球游戏_中国足彩网¥体育资讯$

vbscript Registry 注册表操作实现代码(读写删除)
来源:易贤网 阅读:1246 次 日期:2016-07-05 14:32:57
温馨提示:易贤网小编为您整理了“vbscript Registry 注册表操作实现代码(读写删除)”,方便广大网友查阅!

vbscript Registry 注册表操作实现代码(读写删除)功能代码,需要的朋友可以参考下。

VBScript Code:

代码如下:

' Create a WSH Shell object:

Set wshShell = CreateObject( "WScript.Shell" )

'

' Create a new key:

wshShell.RegWrite "HKCU\TestKey\", ""

' Create a new DWORD value:

wshShell.RegWrite "HKCU\TestKey\DWordTestValue", 1, "REG_DWORD"

' Create a new subkey and a string value in that new subkey:

wshShell.RegWrite "HKCU\TestKey\SubKey\StringTestValue", "Test", "REG_SZ"

' Read the values we just created:

WScript.Echo "HKCU\TestKey\DWordTestValue = " _

& wshShell.RegRead( "HKCU\TestKey\DWordTestValue" )

WScript.Echo "HKCU\TestKey\SubKey\StringTestValue = """ _

& wshShell.RegRead( "HKCU\TestKey\SubKey\StringTestValue" ) & """"

' Delete the subkey and key and the values they contain:

wshShell.RegDelete "HKCU\TestKey\SubKey\"

wshShell.RegDelete "HKCU\TestKey\"

' 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等。

主键路径:

主键路径就是目标键在注册表中的主键位置,各个主键之间用"\"符分隔开。如:"Software\Microsoft\Windows\CurrentVersion\Policies\"

键值:

键值参数直接接在主键路径之后。例如一个完整的路径如下所示:

"HKCR\Software\Microsoft\Windows\CurrentVersion\Policies\NoRun"

方法详解

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\.xxf\value")

'读取.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\.xxf\value1","string"

'在主键.xxf之下新建一个字符串型键值value1,并置其初始值为"string"

OperationRegistry.RegWrite "HKCR\.xxf\value2",1,"REG_DWORD"

'在主键.xxf之下新建一个REG_DWORD型键值value2,并置其初始值为1

OperationRegistry.RegWrite "HKCR\.xxf\value3",0Xff,"REG_BINARY"

'在主键.xxf之下新建一个二进制型键值value3,并置其初始值为十六进制的ff

3、RegDelete操作详解

删除操作RegDelete主要是用来删除注册表中已存在的主键或键值,该操作是一种极其危险的操作,它能将主键或键值毫不留情的在注册表中“砍掉”,无论该键值下面有多重要的数据,它都能畅行无阻,因此在使用该操作时务必小心。

删除操作的参数形式与读操作的参数形式几乎完全相同,只是有一点小小的区别,那就是删除操作不需要将操作的返回值送给某一变量,例如:

代码如下:

'delete.vbs

Dim OperationRegistry

Set OperationRegistry=WScript.CreateObject("WScript.Shell")

OperationRegistry.RegRead("HKCR\.xxf\value")

'删除.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="HKLM\System\CurrentControlSet\Control\

ComputerName\ComputerName\ComputerName"

ComputerName=ReadComputerName.RegRead(RegPath)

MsgBox("计算机名为"&ComputerName)

2、隐藏快捷方式图标上的小箭头

代码如下:

'Hidden.vbs

Dim HiddenArrowIcon

Set HiddenArrowIcon=WScript.CreateObject("WScript.Shell")

Dim RegPath1,RegPath2

RegPath1="HKCR\lnkfile\IsShortCut"

RegPath2="HKCR\piffile\IsShortCut"

HiddenArrowIcon.RegDelete(RegPath1)

HiddenArrowIcon.RegDelete(RegPath2)

3、改造“开始”菜单

代码如下:

'ChangeStartMenu.vbs

Dim ChangeStartMenu

Set ChangeStartMenu=WScript.CreateObject("WScript.Shell")

RegPath="HKCR\Software\Microsoft\Windows\CurrentVersion\Policies\"

Type_Name="REG_DWORD"

Key_Data=1

StartMenu_Run="NoRun"

StartMenu_Find="NoFind"

StartMenu_Close="NoClose"

Sub Change(Argument)

ChangeStartMenu.RegWrite RegPath&Argument,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="HKLM\Software\Microsoft\Windows\CurrentVersion\Run\"

Type_Name="REG_SZ"

Key_Name="AutoRun"

Key_Data="C:\Myfile\autorun.exe"

'该自启动程序的全路径文件名

AutoRunProgram.Write RegPath&Key_Name,Key_Data,Type_Name

'在启动组中添加自启动程序autorun.exe

MsgBox("Success!")

中国足彩网信息请查看脚本栏目
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 新媒体/短视频平台 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 足球游戏_中国足彩网¥体育资讯$ 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65099533/13759567129 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:1093837350(9:00—18:00)版权所有:易贤网
云南网警报警专用图标