VBScript实现对Windows注册表的修改

vbscript|window|注册表

  大名鼎鼎的WSH听说过吗? 它就是Windows Script Host的缩写形式,WSH是Windows平台的脚本指令,它的功能十分强大,并且它还是利用语法结构简单、易学易用且功能强大的JScript和VBScript脚本语言,来实现其卓越的功能的,除了本文介绍的修改注册表之外,它还可以访问Excel文件,也能与网络沟通,当然它最大的优势莫过于它能与操作系统沟通,而修改注册表只是它与操作系统沟通的冰山一角。正是它有如此诸多的优点与实用性,正倍受很多Windows用户的青睐,本文就为大家介绍一二,让各位领略一下WSH的风采。

  用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!")
  ?如果你真想这么做,那就请你作好注册表的备份。

  应用实例

  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!")

时间: 2024-11-08 20:45:34

VBScript实现对Windows注册表的修改的相关文章

用VBScript实现对Windows注册表的修改

vbscript|window|注册表 大名鼎鼎的WSH听说过吗? 它就是Windows Script Host的缩写形式,WSH是Windows平台的脚本指令,它的功能十分强大,并且它还是利用语法结构简单.易学易用且功能强大的JScript和VBScript脚本语言,来实现其卓越的功能的,除了本文介绍的修改注册表之外,它还可以访问Excel文件,也能与网络沟通,当然它最大的优势莫过于它能与操作系统沟通,而修改注册表只是它与操作系统沟通的冰山一角.正是它有如此诸多的优点与实用性,正倍受很多Win

用VBScript实现对Windows注册表的修改详解_资讯中心

大名鼎鼎的WSH听说过吗? 它就是Windows Script Host的缩写形式,WSH是Windows平台的脚本指令,它的功能十分强大,并且它还是利用语法结构简单.易学易用且功能强大的JScript和VBScript脚本语言,来实现其卓越的功能的,除了本文介绍的修改注册表之外,它还可以访问Excel文件,也能与网络沟通,当然它最大的优势莫过于它能与操作系统沟通,而修改注册表只是它与操作系统沟通的冰山一角.正是它有如此诸多的优点与实用性,正倍受很多Windows用户的青睐,本文就为大家介绍一二

使用注册表文件(REG)添加、修改或删除Windows注册表项和值

1. 简介 我们平时大多采用Regedit注册表编辑器来实现对注册表的修改操作,但 是这种手工操作费时费力,当你要对多台PC统一修改注册表时,就要怨念了.并且在某些情 况下,如果注册表编辑器被禁用了,那么这种方法也会失效.于是,推荐大家使用REG文件来 快速完成注册表的修改. REG文件实际上是一种注册表脚本文件,Regedit注册表编辑 器可以使用REG文件来导入.导出注册表的子项和值.双击REG文件(即用Regedit.exe 注册 表编辑器程序运行该文件)即可将其中的数据导入到注册表中.我

注册表被修改的原因及解决办法

一.注册表被修改的原因及解决办法 其实,该恶意网页是含有有害代码的ActiveX网页文件,这些广告信息的出现是因为浏览者的注册表被恶意更改的结果. 1.IE默认连接首页被修改 IE浏览器上方的标题栏被改成"欢迎访问******网站"的样式,这是最常见的篡改手段,受害者众多. 受到更改的注册表项目为: HKEY_LOCAL_MACHINESOFTWAREMicrosoftInternet ExplorerMainStart Page HKEY_CURRENT_USERSoftwareMi

注册表被修改的原因分析和解决方法

注册表被修改的原因分析和解决方法: 其实,该恶意网页是含有有害代码的ActiveX网页文件,这些广告信息的出现是因为浏览者的注册表被恶意更改的结果. 1.IE默认连接首页被修改 IE浏览器上方的标题栏被改成"欢迎访问******网站"的样式,这是最常见的篡改手段,受害者众多. 受到更改的注册表项目为: HKEY_LOCAL_MACHINESOFTWAREMicrosoftInternet ExplorerMainStart Page HKEY_CURRENT_USERSoftwareM

浏览网页注册表被修改之迷及解决办法_注册表

浏览网页会被修改注册表?千真万确!如果你去浏览过下面的网页:http://www.某某.com/default.htm ,你真有生不如死的感觉! 进入该网页会被: 1.修改开始菜单 1)禁止"关闭系统" 2)禁止"运行" 3)禁止"注销" 2.隐藏C盘--你的C盘找不到了 3.禁止使用注册表编辑器regedit 4.禁止使用DOS程序 5.使系统无法进入"实模式" 6.禁止运行任何程序 7.将IE浏览器的首页改为http://

用CB控制Windows注册表

Windows注册表中包含了系统配置.机器硬件配置.Win32应用程序和用户的其他配置信息.注册表根据系统信息分为六个根键(RootKey),其中每个根键各有一个由子键和键值组成的树状结构,每个子键代表一个特定的配置项目. 用C++Builer控制注册表的关键在于了解TRegistry 类.在C++Builder的VCL类库中,提供了TRegistry类,通过在应用程序中生成这个类的实例,我们可以实现对注册表的控制.在TRegistry类中,重点应该掌握如下问题: 1.TRegistry类的生成

WinPE注册表的修改方法

  WinPE注册表的修改方法         有时候我们需要对PE注册表添加一些信息,如何来添加呢?下面这就来告诉你. 使用 Regsnap 等在标准的 Windows 环境下跟踪分析出软件要添加到注册表中的内容,然后将注册表修改条目导出,并改写成批处理文件,保存到软件所在的目录中. 比如对 ACDSEE 这各程序的注册信息跟踪后就保存在: X:PROGRAMS图形图像ACDSEEACDSEE.CMD 建议参照 X:PROGRAMS图形图像ACDSEE 这个程序的保存方式保存你要添加的软件,原

巧用注册表轻松修改Win 2k/XP的默认刷新率_注册表

下面介绍的修改方法只包括对Windows注册表的编辑,因此不需要运行任何来源不明的第三方应用程序. 理论上讲,这种修改方法将与显示驱动程序/适配器无关,因为它修改的是显示器的设置值,而不是显示驱动程序/适配器本身. 重要提示:在修改之前,请确认你的显示器支持你所希望采用的分辨率下的刷新率!后果自负! 假定你已经正确地安装了你的显示器(显示器驱动程序支持你所想要的垂直刷新率,在这个案例里为75Hz),并且你的是"普通的"系统(没有启用多显示器支持等等),请照下面讲的做: 打开注册表编辑器