无忧启动论坛

标题: 注册表导入工具,包含PE和挂载的 [打印本页]

作者: nnkoll    时间: 2025-5-26 17:13
标题: 注册表导入工具,包含PE和挂载的
本帖最后由 nnkoll 于 2025-5-26 17:13 编辑

每次修改PE或者系统,导入的注册表总是需要手动挂载,经过几天的研究,研究出一个程序,具体源码如下:
  1. #cs ----------------------------------------------------------------------------

  2. AutoIt Version: 3.3.16.1
  3. Author:         myName

  4. Script Function:
  5.         Template AutoIt script.

  6. #ce ----------------------------------------------------------------------------

  7. ; Script Start - Add your code below here
  8. #include <MsgBoxConstants.au3>
  9. #include <FileConstants.au3>
  10. #include <WinAPIFiles.au3>

  11. ; 检查 sed.exe 是否存在
  12. Global $sed = @ScriptDir & "\sed.exe"
  13. If Not FileExists($sed) Then
  14.     Exit
  15. EndIf

  16. ; 自动检测系统盘,在PE下导入修改的注册表
  17. Global $systemDrive = ""
  18. For $i = Asc("A") To Asc("Z")
  19.     Local $drive = Chr($i) & ":"
  20.     If FileExists($drive & "\Windows\System32\config\SYSTEM") And _
  21.        (FileExists($drive & "\bootmgr") Or FileExists($drive & "\Windows\System32\winload.efi")) Then
  22.         $systemDrive = $drive
  23.         ExitLoop
  24.     EndIf
  25. Next

  26. If $systemDrive = "" Then
  27.     Exit
  28. EndIf

  29. ; 加载注册表
  30. Global $regSystem = $systemDrive & "\Windows\System32\config\SYSTEM"
  31. Global $regSoftware = $systemDrive & "\Windows\System32\config\SOFTWARE"
  32. Global $regDefault = $systemDrive & "\Windows\System32\config\DEFAULT"
  33. Global $regUserDat = $systemDrive & "\Users\Default\NTUSER.DAT"
  34. RunWait('reg load HKLM\TempSystem "' & $regSystem & '"')
  35. RunWait('reg load HKLM\TempSoftware "' & $regSoftware & '"')
  36. RunWait('reg load HKU\TempDefault "' & $regDefault & '"')
  37. RunWait('reg load HKU\TempUser "' & $regUserDat & '"')

  38. ; 创建临时目录存储处理后的 .reg 文件
  39. Global $tmpDir = @TempDir & "\regtemp"
  40. If FileExists($tmpDir) Then DirRemove($tmpDir, 1)
  41. DirCreate($tmpDir)

  42. ; 处理注册表文件导入
  43. _RegProcess("system.reg", "s/HKEY_LOCAL_MACHINE\\SYSTEM/HKEY_LOCAL_MACHINE\\TempSystem/g")
  44. _RegProcess("software.reg", "s/HKEY_LOCAL_MACHINE\\SOFTWARE/HKEY_LOCAL_MACHINE\\TempSoftware/g")
  45. _RegProcess("default_user.reg", "s/HKEY_USERS\\.DEFAULT/HKEY_USERS\\TempDefault/g")
  46. _RegProcess("default_user.reg", "s/HKEY_CURRENT_USER/HKEY_USERS\\TempUser/g")
  47. _RegProcess("classes_root.reg", "s/HKEY_CLASSES_ROOT/HKEY_LOCAL_MACHINE\\TempSoftware\\Classes/g")
  48. _RegProcess("classes_root.reg", "s/HKEY_CLASSES_ROOT/HKEY_USERS\\TempDefault\\Software\\Classes/g")
  49. _RegProcess("classes_root.reg", "s/HKEY_CLASSES_ROOT/HKEY_USERS\\TempUser\\Software\\Classes/g")

  50. ; 卸载临时注册表
  51. RunWait("reg unload HKLM\TempSystem")
  52. RunWait("reg unload HKLM\TempSoftware")
  53. RunWait("reg unload HKU\TempDefault")
  54. RunWait("reg unload HKU\TempUser")

  55. ; 如果 NTUSER.DAT 存在且不是 NTUSER.MAN,则重命名
  56. If FileExists($regUserDat) And Not FileExists($systemDrive & "\Users\Default\NTUSER.MAN") Then
  57.     FileMove($regUserDat, $systemDrive & "\Users\Default\NTUSER.MAN", $FC_OVERWRITE)
  58. EndIf


  59. ; 注册表处理函数
  60. Func _RegProcess($filename, $sedPattern)
  61.     Local $srcFile = @ScriptDir & "" & $filename
  62.     If Not FileExists($srcFile) Then Return
  63.     Local $outFile = $tmpDir & "" & $filename
  64.     RunWait('"' & $sed & '" "' & $sedPattern & '" "' & $srcFile & '" > "' & $outFile & '"', "", @SW_HIDE)
  65.     RunWait('regedit /s "' & $outFile & '"', "", @SW_HIDE)
  66. EndFunc
复制代码
  1. #cs ----------------------------------------------------------------------------

  2. AutoIt Version: 3.3.16.1
  3. Author:         myName

  4. Script Function:
  5.         Template AutoIt script.

  6. #ce ----------------------------------------------------------------------------

  7. ; Script Start - Add your code below here
  8. #include <MsgBoxConstants.au3>
  9. #include <FileConstants.au3>
  10. #include <WinAPIFiles.au3>
  11. #include <File.au3>

  12. ; 检查 sed.exe 是否存在
  13. Global $sed = @ScriptDir & "\sed.exe"
  14. If Not FileExists($sed) Then Exit

  15. ; 选择挂载系统所在的根目录(如 D:\MountedWindows)
  16. Global $systemFolder = FileSelectFolder("请选择挂载系统的根目录(含 Windows 文件夹)", "", 2)
  17. If @error Or $systemFolder = "" Then Exit

  18. ; 构建注册表文件路径
  19. Global $regSystem   = $systemFolder & "\Windows\System32\config\SYSTEM"
  20. Global $regSoftware = $systemFolder & "\Windows\System32\config\SOFTWARE"
  21. Global $regDefault  = $systemFolder & "\Windows\System32\config\DEFAULT"

  22. ; 允许 NTUSER.DAT 或 NTUSER.MAN 任意一个存在
  23. Global $regUserDat  = ""
  24. If FileExists($systemFolder & "\Users\Default\NTUSER.DAT") Then
  25.     $regUserDat = $systemFolder & "\Users\Default\NTUSER.DAT"
  26. ElseIf FileExists($systemFolder & "\Users\Default\NTUSER.MAN") Then
  27.     $regUserDat = $systemFolder & "\Users\Default\NTUSER.MAN"
  28. Else
  29.     Exit
  30. EndIf

  31. ; 加载脱机注册表
  32. RunWait('reg load HKLM\TempSystem "' & $regSystem & '"')
  33. RunWait('reg load HKLM\TempSoftware "' & $regSoftware & '"')
  34. RunWait('reg load HKU\TempDefault "' & $regDefault & '"')
  35. RunWait('reg load HKU\TempUser "' & $regUserDat & '"')

  36. ; 创建临时目录处理 .reg 文件
  37. Global $tmpDir = @TempDir & "\regtemp"
  38. If FileExists($tmpDir) Then DirRemove($tmpDir, 1)
  39. DirCreate($tmpDir)

  40. ; 注册表导入映射
  41. _RegProcess("system.reg", "s/HKEY_LOCAL_MACHINE\\SYSTEM/HKEY_LOCAL_MACHINE\\TempSystem/g")
  42. _RegProcess("software.reg", "s/HKEY_LOCAL_MACHINE\\SOFTWARE/HKEY_LOCAL_MACHINE\\TempSoftware/g")
  43. _RegProcess("default_user.reg", "s/HKEY_USERS\\.DEFAULT/HKEY_USERS\\TempDefault/g")
  44. _RegProcess("default_user.reg", "s/HKEY_CURRENT_USER/HKEY_USERS\\TempUser/g")
  45. _RegProcess("classes_root.reg", "s/HKEY_CLASSES_ROOT/HKEY_LOCAL_MACHINE\\TempSoftware\\Classes/g")
  46. _RegProcess("classes_root.reg", "s/HKEY_CLASSES_ROOT/HKEY_USERS\\TempDefault\\Software\\Classes/g")
  47. _RegProcess("classes_root.reg", "s/HKEY_CLASSES_ROOT/HKEY_USERS\\TempUser\\Software\\Classes/g")

  48. ; 卸载注册表
  49. RunWait("reg unload HKLM\TempSystem")
  50. RunWait("reg unload HKLM\TempSoftware")
  51. RunWait("reg unload HKU\TempDefault")
  52. RunWait("reg unload HKU\TempUser")

  53. ; 如果使用的是 NTUSER.DAT,重命名为 NTUSER.MAN(仅当 MAN 不存在)
  54. If StringInStr($regUserDat, "NTUSER.DAT") And Not FileExists($systemFolder & "\Users\Default\NTUSER.MAN") Then
  55.     FileMove($regUserDat, $systemFolder & "\Users\Default\NTUSER.MAN", $FC_OVERWRITE)
  56. EndIf

  57. ; 注册表导入处理函数
  58. Func _RegProcess($filename, $sedPattern)
  59.     Local $srcFile = @ScriptDir & "" & $filename
  60.     If Not FileExists($srcFile) Then Return
  61.     Local $outFile = $tmpDir & "" & $filename
  62.     RunWait('"' & $sed & '" "' & $sedPattern & '" "' & $srcFile & '" > "' & $outFile & '"', "", @SW_HIDE)
  63.     RunWait('regedit /s "' & $outFile & '"', "", @SW_HIDE)
  64. EndFunc
复制代码




共两个程序,有个是PE下导入,一个是挂载的系统,自行修改一些代码,做不到完美,请指正


作者: 技束源    时间: 2025-5-26 17:36
很不错 谢谢分享
作者: Bluebells    时间: 2025-5-26 18:03
1. 没看明白为啥一定需要存在 sed.exe 这个文件
2. 为啥要遍历 A~Z 的所有驱动器号, 而不是已使用的驱动器号
3. 判断离线(脱机)系统的驱动器号的逻辑不严谨
4. 好像不需要定义这么多的全局变量吧
...
作者: 小灰兔    时间: 2025-5-26 18:06
谢谢分享
作者: jho    时间: 2025-5-26 18:59

感谢分享
作者: jh198354    时间: 2025-5-26 19:00

谢谢分享
作者: handsome_xiang    时间: 2025-5-26 19:19
感谢分享!
作者: dnine999    时间: 2025-5-26 21:30
感谢分享
作者: yc2428    时间: 2025-5-26 21:40
感谢分享
作者: yaowozhuce    时间: 2025-5-27 00:34

作者: Q646643964    时间: 2025-5-27 03:59
感谢楼主分享
作者: ajlass    时间: 2025-5-27 07:36
感谢分享。
作者: wang1126    时间: 2025-5-27 11:30
谢谢楼主分享
作者: guong    时间: 2025-5-27 14:05
谢谢楼主分享
作者: 燕飞龙    时间: 2025-5-27 15:04
感谢分享
作者: ebaqiang    时间: 2025-5-28 07:50
感谢楼主分享
作者: Siya2025    时间: 7 天前
感谢楼主的分享
作者: neartree    时间: 7 天前
谢谢分享,以我的经验,注册表操作要慎重加慎重,定期备份,如果无备份的情况下,加载配置单元一旦不慎点错,点成导入(如导入PE的software文件),就会成为灾难!!!我就这样弄崩过一次系统,最后各种修复无效,只能重装了。
作者: 790097    时间: 7 天前
谢谢分享




欢迎光临 无忧启动论坛 (http://wuyou.net/) Powered by Discuz! X3.3