无忧启动论坛

标题: 带密码一键部署PE NSIS脚本 重启进入PE一次有效!!! [打印本页]

作者: cls822001    时间: 7 小时前
标题: 带密码一键部署PE NSIS脚本 重启进入PE一次有效!!!
本帖最后由 cls822001 于 2025-11-28 09:15 编辑

带密码一键部署PE NSIS脚本 直接上代码 自己用更改GUID
  1. Unicode false
  2. !include "LogicLib.nsh"
  3. !include "FileFunc.nsh"
  4. !include MUI2.nsh
  5. !define Password "Password2025"
  6. !define GUID "{566C315E-2697-4E54-83FF-45EDDCFF12B5}"
  7. !define PEGUID "{566C315F-2697-4E54-83FF-45EDDCFF12B5}"

  8. Name "欢迎使用WinPE"
  9. OutFile "WinPE安装程序.exe"

  10. ; 界面设置 - 跳过欢迎页面,直接从密码页面开始
  11.   !define MUI_CUSTOMFUNCTION_GUIINIT onGUIInit
  12.   Page Custom PasswordPageShow PasswordPageLeave
  13.   !define MUI_PAGE_CUSTOMFUNCTION_PRE 'CopyFiles'
  14.   !define MUI_PAGE_CUSTOMFUNCTION_SHOW MyInstFiles
  15.   !insertmacro MUI_PAGE_INSTFILES

  16. !insertmacro MUI_LANGUAGE "SimpChinese"

  17. Icon start.ico
  18. ShowInstDetails nevershow
  19. AutoCloseWindow true
  20. BrandingText "在线一键安装系统"
  21. Caption ""

  22. Function PasswordPageShow
  23.   !insertmacro MUI_HEADER_TEXT "输入密码" "安装程序需要一个正确的安装密码才能继续。"
  24.   PassDialog::InitDialog /NOUNLOAD Password /HEADINGTEXT "请致电 XXXXXXXXXXX 索取密码。" /GROUPTEXT "密码输入框"
  25.   Pop $R0
  26.   GetDlgItem $R1 $HWNDPARENT 1
  27.   ShowWindow $R1 ${SW_HIDE}
  28.   GetDlgItem $R1 $HWNDPARENT 2 ; 取消按钮ID=2
  29.   ShowWindow $R1 ${SW_HIDE}
  30.   GetDlgItem $R1 $HWNDPARENT 3 ; 后退按钮ID=3
  31.   ShowWindow $R1 ${SW_HIDE}
  32.   PassDialog::Show
  33. FunctionEnd

  34. Function PasswordPageLeave
  35.   Pop $R0
  36.   StrCmp $R0 "${Password}" password_correct
  37.   MessageBox MB_OK|MB_ICONEXCLAMATION "密码输入错误!请输入正确的安装密码!"
  38.   Abort
  39. password_correct:
  40.   MessageBox MB_OK|MB_ICONINFORMATION "密码输入正确!请点击$"确定$"继续进行安装!"
  41. FunctionEnd


  42. Section "主程序" SecMain
  43.         SetDetailsPrint textonly
  44.         DetailPrint "ToDesk正在下载最新PE文件...."
  45.         SetDetailsPrint listonly
  46.         SetOutPath C:\YXPE
  47. ; 本地文件示例;YXPE.7z 文件包括 boot.sdi winpe.wim
  48. ;        File YXPE.7z
  49. ;        Nsis7z::ExtractWithDetails "C:\YXPE\YXPE.7z" "文件解压进度 %s..."
  50. ;        Delete "C:\YXPE\YXPE.7z"
  51. ; 网络下载文件
  52.   NScurl::http GET "http://down.jywangluo.cn:88/PE/YXPE.7z" "$PLUGINSDIR\YXPE.7z"
  53.   Nsis7z::ExtractWithDetails "$PLUGINSDIR\YXPE.7z" "文件解压进度 %s..."
  54.   SetFileAttributes "C:\YXPE" HIDDEN
  55.   SetDetailsPrint textonly
  56.         DetailPrint "添加启动菜单...."
  57.         SetDetailsPrint listonly
  58.         System::Call "Kernel32::Wow64EnableWow64FsRedirection(i 0)"
  59.         nsExec::Exec 'bcdedit /create ${GUID} /device'
  60.   nsExec::Exec 'bcdedit /set ${GUID} ramdisksdidevice partition=C:'
  61.   nsExec::Exec 'bcdedit /set ${GUID} ramdisksdipath \YXPE\boot.sdi'
  62.   nsExec::Exec 'bcdedit /create ${PEGUID} /d "WinPE 网络维护环境" /application osloader'
  63.   nsExec::Exec 'bcdedit /set ${PEGUID} device ramdisk=[C:]\YXPE\winpe.wim,${GUID}'
  64.   nsExec::Exec 'bcdedit /set ${PEGUID} osdevice ramdisk=[C:]\YXPE\winpe.wim,${GUID}'
  65.   ReadEnvStr $0 "firmware_type"
  66.   ${If} $0 == "UEFI"
  67.     nsExec::Exec 'bcdedit /set ${PEGUID} path \windows\system32\boot\winload.efi'
  68.   ${Else}
  69.     nsExec::Exec 'bcdedit /set ${PEGUID} path \windows\system32\boot\winload.exe'
  70.   ${EndIf}
  71.   nsExec::Exec 'bcdedit /set ${PEGUID} locale zh-CN'
  72.   nsExec::Exec 'bcdedit /set ${PEGUID} systemroot \windows'
  73.   nsExec::Exec 'bcdedit /set ${PEGUID} winpe yes'
  74.   nsExec::Exec 'bcdedit /set ${PEGUID} detecthal yes'
  75.   nsExec::Exec 'bcdedit /displayorder ${PEGUID} /addlast'
  76.   nsExec::Exec 'bcdedit /bootsequence ${PEGUID} /addfirst'
  77.   nsExec::Exec 'bcdedit /timeout 10'
  78.   MessageBox MB_YESNO "立即重启系统进入PE点是!稍后自行重启点否" IDYES true IDNO false
  79.   true:
  80.   Reboot
  81.   false:
  82.   Quit
  83. SectionEnd

  84. Function .onInit
  85.   BrandingURL::Unload
  86. FunctionEnd

  87. Function MyInstFiles
  88.    GetDlgItem $0 $HWNDPARENT 1 ;下一步
  89.    ShowWindow $0 ${SW_HIDE}
  90.    GetDlgItem $0 $HWNDPARENT 2 ;取消
  91.    ShowWindow $0 ${SW_HIDE}
  92.    GetDlgItem $1 $HWNDPARENT 3 ;上一步
  93.    ShowWindow $1 ${SW_HIDE}
  94.    GetDlgItem $0 $HWNDPARENT 1037
  95.    SendMessage $0 ${WM_SETTEXT} 0 "STR: "
  96.    GetDlgItem $0 $HWNDPARENT 1038
  97.    SendMessage $0 ${WM_SETTEXT} 0 "STR:正在下载最新PE文件,请稍候...."
  98. FunctionEnd

  99. Function 'CopyFiles'
  100. GetDlgItem $R0 $HWNDPARENT 1
  101. System::Call 'user32::GetWindowLong(i $hwndparent,i -16)i.r0'
  102.   intop $1 0x80000 ~
  103.   intop $0 $0 & $1
  104. System::Call 'user32::SetWindowLong(i $hwndparent,i -16,i $0)i'
  105. FunctionEnd

  106. Function onGUIInit
  107.    BrandingURL::Set /NOUNLOAD "0" "0" "255" "http://down.jywangluo.cn:88"
  108. FunctionEnd
复制代码



作者: a66    时间: 7 小时前
支持折腾~~~~~~~~
作者: 路路路过    时间: 7 小时前
感谢大佬分享
作者: cncecpcy    时间: 6 小时前
好。。。。。。。
作者: win82    时间: 6 小时前
感谢分享
作者: wn168cn@163.com    时间: 6 小时前
支持原创
作者: yhage    时间: 6 小时前
感谢分享脚本
作者: yzszh64    时间: 5 小时前
感谢,辛苦了。
作者: hmaaaa    时间: 5 小时前
感謝大大分享!^^ 辛苦了!
作者: 小灰猪    时间: 5 小时前
感谢分享
作者: 董大    时间: 5 小时前
支持原创,谢谢楼主的分享!
作者: eve0079    时间: 5 小时前
感谢分享
作者: ouanyu    时间: 4 小时前
支持折腾~~~~~~~~
作者: xiaozgl119    时间: 4 小时前
谢谢分享
作者: handsome_xiang    时间: 4 小时前
感谢分享!
作者: smile_z    时间: 4 小时前
感谢分享
作者: cncecpcy    时间: 3 小时前
好。。。。。。。。。。
作者: wang1126    时间: 3 小时前
谢谢楼主分享
作者: dksoft    时间: 3 小时前
感谢分享
作者: fegr    时间: 2 小时前
多谢楼主分享
作者: guong    时间: 2 小时前
感谢分享!
作者: zainijia    时间: 2 小时前
感谢分享脚本
作者: 简减    时间: 1 小时前
感谢分享
作者: 进士小站    时间: 1 小时前
谢谢分享一定要试试
作者: 阳光海风_1    时间: 1 小时前

感谢大佬分享
作者: TiAmo51357    时间: 半小时前
看为懂,谢谢!
作者: lovekix    时间: 半小时前
这是不是   给 系统加了一个 锁     
购买 之后 才 可以使用
但是这密码  太单一   (一人购买 其他人也可以 使用把)
作者: gudezheng    时间: 6 分钟前
感谢分享




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