k-ist-k
Goto Top

CMD startet CMD als Admin inkl. Skript

Hallo,

ich möchte ein Skript (ohne Admin) starten, das ein Skript startet (und als Admin ausführt)

Skript A: (liegt am USB Stick und wird von einem User ohne Admin Rechten doppel geklickt)
REM führe nachfolgendes Skript als Admin aus
runas /user:Administrator "cmd /c D:\SkriptB.cmd"  

Skript B: (liegt am USB Stick, wird von Skript A gestartet und verlangt ein Passwort)
REM Teste ob Skript als Admin gestartet wird
echo "Test" >> C:\test.txt  

Hier der Auszug vom CMD Fenster (das als nicht Admin gestartet ist)
fehler

---

Das Problem ist, das das Skript als nicht Admin ausgeführt wird.
schreibt man aber:
runas /user:Administrator cmd
dann wird ein neues CMD Fenster geöffnet mit Admin Rechte.
Geht das nicht, wenn man einen Pfad mitgibt ?


Auf dem System wo ich bin, ist die Rechte Maustaste deaktiviert.
Und ich möchte mir es sparen, das ich ein CMD als Admin aufrufe und zum Skript navigiere.


Danke

LG K

Content-ID: 551799

Url: https://administrator.de/contentid/551799

Ausgedruckt am: 25.11.2024 um 14:11 Uhr

TomTomBon
Lösung TomTomBon 26.02.2020 um 13:44:25 Uhr
Goto Top
Moin Moin,

Was Ich für Admin Rechte Abfrage benutze ist das folgende:

@echo off &setlocal enableextensions ENABLEDELAYEDEXPANSION 
@prompt -$G
echo Run shell as UAC ADMIN

:: Automatically check & get admin rights
::
:: A sincere Thanks to Matt (http://stackoverflow.com/users/1016343/matt) over @ Stackoverflow.com (http://stackoverflow.com/questions/7044985/how-can-i-auto-elevate-my-batch-file-so-that-it-requests-from-uac-admin-rights) for sharing this great piece of scripting.
::

:checkPrivileges 
NET FILE 1>NUL 2>NUL
if /I '%errorlevel%' == '0' ( goto gotPrivileges ) else ( goto getPrivileges )   
 
:getPrivileges 
if /I '%1'=='ELEV' (shif /It & goto gotPrivileges)    
ECHO. 
ECHO **************************************
ECHO Invoking UAC for Privilege Escalation 
ECHO **************************************
 
setlocal DisableDelayedExpansion
set "batchPath=%~0"  
setlocal EnableDelayedExpansion
ECHO Set UAC = CreateObject^("Shell.Application"^) > "%temp%\OEgetPrivileges.vbs"   
ECHO UAC.ShellExecute "!batchPath!", "ELEV", "", "runas", 1 >> "%temp%\OEgetPrivileges.vbs"   
"%temp%\OEgetPrivileges.vbs"   
exit /B 
cls


:gotPrivileges 
::Persoenliches Skript



Das fragt einfach ab ob das Skript elevated läuft.
Wenn nicht fragt es danach face-smile

Just my Senf
Tom
K-ist-K
K-ist-K 26.02.2020 um 14:29:39 Uhr
Goto Top
wow es funktioniert.
Auf das wäre ich nie draufgekommen xD

Einfach unten, das einfügen was man benötigt.
Es ist super.
Danke
colinardo
colinardo 26.02.2020 aktualisiert um 16:56:32 Uhr
Goto Top
Servus.
Mit ein bisschen PS statt VBS in der Batch geht es auch noch etwas kompakter
@echo off
net session >nul 2>&1 || (powershell -EP Bypass -NoP -C start "%~0" -verb runas &exit /b)  
Grüße Uwe
K-ist-K
K-ist-K 26.02.2020 um 18:08:20 Uhr
Goto Top
Danke für eine Alternative
TomTomBon
TomTomBon 02.03.2020 um 16:26:58 Uhr
Goto Top
Danke für den Snippet.

Ist noch schöner als VBS face-smile

Ich teste mal wie Ich es nehmen kann bei mir.

So long
Tom
TomTomBon
TomTomBon 02.03.2020 um 17:10:14 Uhr
Goto Top
Ich bin Neugierig gewesen.

Wie zu erwarten, und gehofft, Schneller face-smile

Nochmals Danke!


Mein Script um das von einem beliebigen Ort lokal zu holen und lokal unter c:\tmp-data auszufuehren face-smile

@echo off 
setlocal enableextensions ENABLEDELAYEDEXPANSION 
@prompt -$G

md "c:\TMP-DATA"  
set Auszufuehrend="c:\TMP-DATA\%~n0.cmd"  
copy "%~0" "c:\TMP-DATA\%~n0.cmd"  


:ask_for_ADMIN-Rights
net session >nul 2>&1 || (powershell -EP Bypass -NoP -C start '"%Auszufuehrend%'" -verb runas &exit /b)  
timeout /t 3 >NUL


:Get-ADMIN-Rights