Хорошо, причина , по которой это не работает, это модель безопасности в 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 , и там еще хуже, потому что вы даже не получите правильные пользовательские переменные.