0

我有批处理文件,即 test.bat 。我需要以管理员模式运行 postgresql 命令。基本上该命令用于为 postgres 设置密码。我试过了

C:/Users/pathfinder> runas /user:Administrator net user postgres postgres

但它不工作。

4

1 回答 1

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"

并在上述代码的下方编写您的批处理文件脚本。它将帮助您以管理员身份执行命令。

于 2013-08-21T07:10:19.897 回答