我有批处理文件,即test.bat。我需要以管理员模式运行postgresql命令。 基本上该命令用于为postgres设置密码。 我试过了
C:/用户/探路> runas / user:管理员网络用户postgres postgres
但它没有成功。
答案 0 :(得分:1)
我试过这段代码。它工作,如果我直接运行批处理文件,即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"
在上面的代码下面编写批处理文件脚本。 它将帮助您以管理员身份执行命令。