Хорошо, причина , по которой это не работает, это модель безопасности в Windows Vista и новее.
Учетная запись в группе администраторов по-прежнему выполняет все, что явно не повышен как ограниченный пользователь. Исключением является учетная запись Administrator
, которая запускает все с повышенными правами. По этой причине обычно считается плохим использование в качестве учетной записи для входа и обычно отключено.
Вы можете включить его, а затем runas
как эту учетную запись. Это создает несколько проблем - теперь вы работаете в среде другого пользователя, в которой могут быть установлены разные переменные среды. 1
Лучшим способом сделать это было бы повышение уровня вашего текущего пользователя через UAC. К сожалению, стандартная командная строка не включает эту возможность, но это могут сделать как сторонние программы, так и встроенные PowerShell и WSHell (VBScript).
Исходя из моего другого ответа, вы можете вызвать команду PowerShell напрямую с powershell -c
:
powershell -c start -verb runas notepad C:\Windows\System32\drivers\etc\hosts
который в основном говорит PowerShell выполнить следующее (start
называется псевдонимом Start-Process
):
Start-Process -Verb "runas" notepad C:\Windows\System32\drivers\etc\hosts
Хитрость здесь в том, чтобы передать глагол runas
, вызывая UAC.
Ни Start-Process -Verb runas
ни стандартные cmd runas
не пропустят текущий рабочий каталог, поэтому всегда используйте полный путь в любых командах, которые вы повышаете таким образом.
Также обратите внимание, что некоторые аргументы, такие как -c
могут конфликтовать с аргументами Start-Process
, поэтому самый безопасный способ:
powershell "-c start -verb runas commandname -argumentlist 'arg1 arg2'"
1 Примечание: это относится только к переменным окружения пользователя «s. Переменные среды, которые вы установили в родительском процессе , не передаются UAC ! Это также относится к runas
, и там еще хуже, потому что вы даже не получите правильные пользовательские переменные.