如何以管理员模式运行命令

时间:2013-08-21 06:40:12

标签: postgresql batch-file

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

C:/用户/探路> runas / user:管理员网络用户postgres postgres

但它没有成功。

1 个答案:

答案 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"

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