IT备忘录

您现在的位置是:首页 > 教程 > 编程开发

编程开发

NSIS读取注册表 NSIS写入/删除注册表键值基础入门教程

2022-04-10 18:14:48编程开发
NSIS是一个非常知名的小巧且功能强大的安装程序打包工具,对于新手来说,很多人不知道NSIS读取注册表、NSIS写入/删除注册表键值怎么操作,下面IT备忘录小编就给大家分享NSIS基础

NSIS是一个非常知名的小巧且功能强大的安装程序打包工具,对于新手来说,很多人不知道NSIS读取注册表、NSIS写入/删除注册表键值怎么操作,下面IT备忘录小编就给大家分享NSIS基础入门教程之:NSIS读取/写入/删除注册表的操作命令代码。

NSIS读取注册表 NSIS写入/删除注册表键值基础入门教程

方法步骤:

1、WriteRegStr

作用:把字符串写入注册表。

WriteRegStr HKLM "Software\My Company\My Software" "String Value" "dead beef"

2、WriteRegExpandStr

作用:将一个字符串写入注册表

root_key  必须是以下之一:

HKCR  或  HKEY_CLASSES_ROOT

HKLM  或  HKEY_LOCAL_MACHINE

HKCU  或  HKEY_CURRENT_USER

HKU  或  HKEY_USERS

HKCC  或  HKEY_CURRENT_CONFIG

HKDD  或  HKEY_DYN_DATA

HKPD  或  HKEY_PERFORMANCE_DATA

SHCTX  或  SHELL_CONTEXT

如果  root_key  是  SHCTX  或  SHELL_CONTEXT,它会被替换成  HKLM  如果  SetShellVarContext  设置为  所有  与  HKCU 如果  SetShellVarContext  设置为  当前。

如果无法将字符串写入注册表,则会设置错误标志。WriteRegStr的字符串类型为REG_SZ,WriteRegExpandStr为REG_EXPAND_STR。如果注册表项不存在,则将创建它

WriteRegExpandStr HKLM "Software\My Company\My Software" "Expand String Value" "%WINDIR%\ notepad.exe"

3、ReadRegDWORD

作用:从注册表中读取32位DWORD到用户变量$ x。root_key的有效值列在WriteRegStr下。

如果DWORD不存在,将设置错误标志并将$ x设置为空字符串(“”为0)。如果该值存在但不是DWORD,则将其作为字符串读取,并将设置错误标志。

ReadRegDWORD $0 HKLM Software \ NSIS VersionBuild

4、DeleteRegKey

作用:删除注册表项。

如果指定了/ ifempty,则只有在没有子项的情况下才会删除注册表项(否则,将删除整个注册表树)。root_key的有效值列在WriteRegStr下  。如果无法从注册表中删除密钥(或者如果它不存在,则设置错误标志)

[/ ifempty] root_key子项

DeleteRegKey HKLM "Software\My Company\My Software"
DeleteRegKey /ifempty HKLM "Software\A key that might have subkeys"

5、DeleteRegValue

作用:删除注册表值

root_key的有效值列在WriteRegStr下。如果无法从注册表中删除该值(或者如果它不存在,则设置错误标志)。

DeleteRegValue HKLM "Software\My Company\My Software" "some value"

6、EnumRegKey

作用:user_var(输出)root_key子键索引

使用root_key \ Subkey中的'index'th注册表项的名称设置用户变量$ x。root_key的有效值列在WriteRegStr下。如果没有其他键,则返回空字符串,并返回空字符串,并在出现错误时设置错误标志。

StrCpy $0 0
loop:
EnumRegKey $1 HKLM Software $0
StrCmp $1 "" done
IntOp $0 $0 + 1
MessageBox MB_YESNO|MB_ICONQUESTION "$1$\n$\nMore?" IDYES loop
done:

7、EnumRegValue

作用:user_var(输出)root_key子键索引

使用root_key \ Subkey中'index'th注册表值的名称设置用户变量$ x。root_key的有效值列在WriteRegStr下。返回一个空字符串,如果没有更多值或者有错误,则设置错误标志。

StrCpy $0 0
loop:
ClearErrors
EnumRegValue $1 HKLM Software\Microsoft\Windows\CurrentVersion $0
IfErrors done
IntOp $0 $0 + 1
ReadRegStr $2 HKLM Software\Microsoft\Windows\CurrentVersion $1
MessageBox MB_YESNO|MB_ICONQUESTION "$1 = $2$\n$\nMore?" IDYES loop
done:

NSIS 检测程序版本号、注册表的写入与读取实例分享

!define PRODUCT_NAME "pkpm"
!define PRODUCT_VERSION "1.0"
!define PRODUCT_PUBLISHER "My company, Inc."
!define PRODUCT_UNINST_KEY "Software\Microsoft\Windows\CurrentVersion\Uninstall\${PRODUCT_NAME}"
!define PRODUCT_INSTALL_KEY "Software\Microsoft\Windows\CurrentVersion\Install\${PRODUCT_NAME}"
!define PRODUCT_UNINST_ROOT_KEY "HKLM"

#检查程序的版本号
Function CompareVersion

#使用读取注册表检测版本号
 ReadRegStr $0 HKLM ${PRODUCT_INSTALL_KEY} "Version"   ;PRODUCT_VERSION      ;用户变量(输出) 根键 子键 项

 ${IF} $0 != ""
   IntCmp ${PRODUCT_VERSION} $0 0 Old New
    MessageBox MB_YESNO  "安装程序检测到 $PRODUCT_NAME 已经安装,是否覆盖安装" IDYES Y IDNO N
   N:  
    Quit
   Old:
     MessageBox MB_ICONSTOP "安装程序检测到 $PRODUCT_NAME 已经安装了更新版本"
     Quit
   New:
     MessageBox MB_ICONSTOP "安装程序检测到 $PRODUCT_NAME 已经安装了旧版本,继续更新安装"
 ${ENDIF}
 Y:
FunctionEnd

#写入注册表的实例
WriteUninstaller "$INSTDIR\uninst.exe"  ;生成卸载exe,自动调用section Uninstall
WriteRegStr HKLM "${PRODUCT_INSTALL_KEY}" "Version" "${PRODUCT_VERSION}"   ; 根键 子键 项 值

以上就是IT备忘录小编给大家分享的NSIS读取/写入/删除注册表操作命令代码,如果本教程对您有帮助,请转载分享并附上本页面地址。

相关内容标签

文章评论