我有批处理文件,即 test.bat 。我需要以管理员模式运行 postgresql 命令。基本上该命令用于为 postgres 设置密码。我试过了
C:/Users/pathfinder> runas /user:Administrator net user postgres postgres
但它不工作。
我有批处理文件,即 test.bat 。我需要以管理员模式运行 postgresql 命令。基本上该命令用于为 postgres 设置密码。我试过了
C:/Users/pathfinder> runas /user:Administrator net user postgres postgres
但它不工作。
我试过这段代码。如果我直接运行批处理文件,即 test.exe,它可以工作,但如果我将此文件配置到高级安装程序并通过 .exe 文件运行,它会进入终端打开的无限循环。
只需在批处理文件的开头添加这些代码:
@ECHO OFF
:: BatchGotAdmin
:-------------------------------------
REM --> Check for permissions
>nul 2>&1 "%SYSTEMROOT%\system32\cacls.exe" "%SYSTEMROOT%\system32\config\system"
REM --> If error flag set, we do not have admin.
if '%errorlevel%' NEQ '0' (
echo Requesting administrative privileges...
goto UACPrompt
) else ( goto gotAdmin )
:UACPrompt
echo Set UAC = CreateObject^("Shell.Application"^) > "%temp%\getadmin.vbs"
echo UAC.ShellExecute "%~s0", "", "", "runas", 1 >> "%temp%\getadmin.vbs"
"%temp%\getadmin.vbs"
exit /B
:gotAdmin
if exist "%temp%\getadmin.vbs" ( del "%temp%\getadmin.vbs" )
pushd "%CD%"
CD /D "%~dp0"
并在上述代码的下方编写您的批处理文件脚本。它将帮助您以管理员身份执行命令。