Moo*_*ght 9 installer uac nsis
我有一个适用于大型应用程序的NSIS脚本.我已经在网上阅读了很多线程,但无法得到以下明确答案:是否可以使用NSIS安装应用程序,当启动时(无论用户类型如何)自动以管理员身份运行?如果可能的话,如何实现?
注意:我已经强制要求NSIS包必须像admin使用一样运行
RequestExecutionLevel admin
Run Code Online (Sandbox Code Playgroud)
我已经尝试使用此方法将UAC要求写入应用程序注册表项,但我无法获得RUNASADMIN编译命令,因为它不是NSIS所需的格式.
And*_*ers 19
为了确保安装程序通常以管理员身份运行,我推荐这个小例子:
Outfile RequireAdmin.exe
RequestExecutionLevel admin ;Require admin rights on NT6+ (When UAC is turned on)
!include LogicLib.nsh
Function .onInit
UserInfo::GetAccountType
pop $0
${If} $0 != "admin" ;Require admin rights on NT4+
MessageBox mb_iconstop "Administrator rights required!"
SetErrorLevel 740 ;ERROR_ELEVATION_REQUIRED
Quit
${EndIf}
FunctionEnd
Page InstFile
Section
SectionEnd
Run Code Online (Sandbox Code Playgroud)
安装的应用程序应该执行类似的步骤,如果它总是需要以管理员身份运行,对于Win32应用程序将是:
requestedExecutionLevel元素levelrequireAdministrator如果"自动以管理员身份运行"意味着绕过UAC提升,那么不可能实现这一点,UAC的重点是允许用户确认/拒绝特权操作!一些应用程序通过安装NT服务来解决这个问题,该服务执行代表应用程序所需的任何操作.我不建议这样做,因为它会向用户提供服务,并且如果服务编码不正确,可能会削弱系统的安全性.
如果您没有编写正在安装的应用程序,那么您的选项会受到更多限制.如果应用程序根本没有清单,则可以使用external(myapp.exe.manifest)清单.
在AppCompatFlags键下设置RUNASADMIN字符串并不是安装程序应该做的事情,这些兼容性选项应该由用户控制,而不是应用程序.
您链接的论坛帖子还告诉您有关在快捷方式上设置标志的两种 方法SLDF_RUNAS_USER,这不能确保应用程序在所有情况下都以管理员身份启动,只有当应用程序从快捷方式启动但它可能是您唯一的选项如果您无法更改应用程序本身...