Lors de l'exécution d'un script de ligne de commande, est-il possible d'obtenir le nom de l'utilisateur actuel?
159
Lors de l'exécution d'un script de ligne de commande, est-il possible d'obtenir le nom de l'utilisateur actuel?
Réponses:
Vous pouvez utiliser la variable username:
%USERNAME%
la source
Nom d'utilisateur:
Nom de domaine:
Vous pouvez obtenir une liste complète des variables d'environnement en exécutant la commande à
set
partir de l'invite de commande.la source
Utilisez simplement cette commande dans l'invite de commande
la source
whoami
, je reçoisdesktop-machine\bballdave025
. Il y a deux parties, vues via: 1)echo %USERNAME%
, résultatbballdave025
; 2)echo %USERDOMAIN%
, résultatDESKTOP-MACHINE
. Je suppose que l'on pourrait dire que le 'nom d'utilisateur complet' est disponible viaecho %USERDOMAIN%\%USERNAME%
(ce résultatDESKTOP-MACHINE\bballdave025
, correspond à celui dewhoami
, en ignorant la casse), ou même viaecho %USERNAME%@%USERDOMAIN%
, resultbballdave025@DESKTOP-MACHINE
. Tout dépend de ce dont l'utilisateur (pour nous, l'OP) a besoin , c'est-à-dire si la partie domaine est importante.Ça devrait être dedans
%USERNAME%
. Évidemment, cela peut être facilement usurpé, alors ne vous fiez pas à cela pour la sécurité.Conseil utile: tapez
set
une invite de commande listera toutes les variables d'environnement.la source
%USERNAME%
est la bonne réponse en batch et autre dans les environnements Windows.Une autre option consiste à utiliser
%USERPROFILE%
pour obtenir le chemin de l'utilisateur, commeC:\Users\username
.la source
La réponse dépend du langage de "script de ligne de commande" dans lequel vous vous trouvez.
Cmd
Dans l'ancienne
cmd.exe
invite de commande ou dans un script.bat
ou.cmd
, vous pouvez utiliser les éléments suivants:%USERNAME%
- Obtient juste le nom d'utilisateur.%USERDOMAIN%
- Obtient le domaine de l'utilisateur.PowerShell
Dans l'invite de commandes PowerShell ou un script
.ps1
ou.psm1
, vous pouvez utiliser les éléments suivants:[System.Security.Principal.WindowsIdentity]::GetCurrent().Name
- Vous donne le nom d'utilisateur complet (par exemple, domaine \ nom d'utilisateur). C'est également la méthode la plus sûre car elle ne peut pas être remplacée par l'utilisateur comme les autres$Env
variables ci-dessous.$Env:Username
- Obtient juste le nom d'utilisateur.$Env:UserDomain
- Obtient le domaine de l'utilisateur.$Env:ComputerName
- Obtient le nom de l'ordinateur.la source
% USERNAME% vous obtiendra le nom d'utilisateur du processus en cours d'exécution. Selon la façon dont vous exécutez votre fichier de commandes, ce n'est pas nécessairement le même que le nom de l'utilisateur actuel. Par exemple, vous pouvez exécuter votre fichier de commandes via une tâche planifiée, à partir d'un service, etc.
Voici un moyen plus sûr d'obtenir le nom d'utilisateur de l'utilisateur actuellement connecté en grattant le nom de l'utilisateur qui a lancé la tâche explorer.exe:
la source
J'utilise cette méthode pour écrire des fichiers batch pour les tests.
Puisque vous devez inclure le mot de passe en texte brut si une authentification est requise, je ne l'utiliserai que dans un environnement complètement privé où les autres utilisateurs ne peuvent pas le voir ou si un utilisateur voyant le mot de passe n'aurait aucune conséquence.
J'espère que cela aide quelqu'un.
la source
Je suis toujours ennuyé de voir que Windows n'a pas certains des petits utilitaires de script plus utiles d'Unix, tels que who / whoami , sed et AWK . Quoi qu'il en soit, si vous voulez quelque chose d'infaillible, obtenez Visual Studio Express et compilez ce qui suit:
Et utilisez simplement cela dans votre fichier de commandes.
la source
net config Workstation | find "User name"
whoami
est disponible à partir de Windows Vista.Dans la plupart des cas, la variable% USERNAME% sera ce que vous voulez.
Cependant, si vous exécutez un shell cmd élevé,% USERNAME% indiquera le nom de l'administrateur au lieu de votre propre nom d'utilisateur. Si vous voulez connaître ce dernier, lancez:
la source
C'est la principale différence entre la variable username et la commande whoami:
la source
Dans un contexte standard, chaque utilisateur connecté détient un processus explorer.exe: La commande [tasklist / V | find "explorer"] retourne une ligne qui contient le propriétaire du processus explorer.exe, avec une regex adaptée il est possible d'obtenir les valeur. Cela fonctionne également parfaitement sous Windows 7.
Dans de rares cas, explorer.exe est remplacé par un autre programme, le filtre de recherche peut être adapté pour correspondre à ce cas. Si la commande renvoie une ligne vide, il est probable qu'aucun utilisateur ne soit connecté. Avec Windows 7, il est également possible d'exécuter [session de requête | trouver ">"].
la source
Pour ce qui est de trouver la meilleure réponse de BlueBearr (pendant que j'exécute mon script batch avec par exemple les droits SYSTEM), je dois y ajouter quelque chose. Parce que dans ma version linguistique Windows (polonais), la ligne qui doit être interceptée par "%% a %% b" == "Nom d'utilisateur:" devient VRAIMENT COMPLIQUE (elle contient des caractères diacritiques dans ma langue), je saute les 7 premières lignes et opérer le 8.
la source