Get-Credential

Získá objekt přihlašovacích údajů na základě uživatelského jména a hesla.

Syntax

Get-Credential
   [[-Credential] <PSCredential>]
   [<CommonParameters>]
Get-Credential
   [-Message <String>]
   [[-UserName] <String>]
   [-Title <String>]
   [<CommonParameters>]

Description

Rutina Get-Credential vytvoří objekt přihlašovacích údajů pro zadané uživatelské jméno a heslo. Objekt přihlašovacích údajů můžete použít v operacích zabezpečení.

Rutina Get-Credential vyzve uživatele k zadání hesla nebo uživatelského jména a hesla. Pomocí parametru Message můžete zadat přizpůsobenou zprávu pro výzvu.

Ve Windows PowerShellu 5.1 a starším zobrazí Windows dialogové okno s výzvou k zadání uživatelského jména a hesla. V PowerShellu 6.0 a novějším se výzva zobrazí v konzole pro všechny platformy.

Příklady

Příklad 1

$c = Get-Credential

Tento příkaz získá objekt přihlašovacích údajů a uloží ho $c do proměnné.

Po zadání příkazu se zobrazí výzva k zadání uživatelského jména a hesla. Když zadáte požadované informace, rutina vytvoří objekt PSCredential představující přihlašovací údaje uživatele a uloží ho do $c proměnné.

Objekt můžete použít jako vstup pro rutiny, které požadují ověření uživatele, jako jsou například rutiny s parametrem Credential . Někteří poskytovatelé, kteří jsou nainstalováni pomocí PowerShellu , ale parametr Credential nepodporují.

Příklad 2

$c = Get-Credential -credential User01
$c.Username
User01

Tento příklad vytvoří přihlašovací údaje, které obsahují uživatelské jméno bez názvu domény.

První příkaz získá přihlašovací údaje s uživatelským jménem User01 a uloží ho $c do proměnné. Druhý příkaz zobrazí hodnotu vlastnosti Username výsledného objektu pověření.

Příklad 3

$Credential = $host.ui.PromptForCredential("Need credentials", "Please enter your user name and password.", "", "NetBiosUserName")

Tento příkaz používá metodu PromptForCredential k zobrazení výzvy uživateli k zadání uživatelského jména a hesla. Příkaz uloží výsledné přihlašovací údaje do $Credential proměnné.

Metoda PromptForCredential je alternativou k použití rutiny Get-Credential . Při použití PromptForCredential můžete zadat popis, zprávy a uživatelské jméno, které se zobrazí na příkazovém řádku.

Další informace najdete v dokumentaci PromptForCredential v sadě SDK.

Příklad 4

Tento příklad ukazuje, jak vytvořit objekt přihlašovacích údajů, který je identický s objektem, který Get-Credential se vrátí bez výzvy uživatele. Tato metoda vyžaduje heslo ve formátu prostého textu, které může porušit standardy zabezpečení v některých podnicích.

$User = "Domain01\User01"
$PWord = ConvertTo-SecureString -String "P@sSwOrd" -AsPlainText -Force
$Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList $User, $PWord

První příkaz uloží název uživatelského účtu do parametru $User . Hodnota musí mít formát Domain\User nebo ComputerName\User.

Druhý příkaz pomocí rutiny ConvertTo-SecureString vytvoří zabezpečený řetězec z hesla ve formátu prostého textu. Příkaz používá parametr AsPlainText k označení, že řetězec je prostý text a parametr Force k potvrzení, že rozumíte rizikům použití prostého textu.

Třetí příkaz používá rutinu New-Object k vytvoření objektu PSCredential z hodnot v $User proměnných a $PWord proměnných.

Příklad 5

Get-Credential -Message "Credential are required for access to the \\Server1\Scripts file share." -User Server01\PowerUser

PowerShell Credential Request
Credential are required for access to the \\Server1\Scripts file share.
Password for user Server01\PowerUser:

Tento příkaz používá parametry Message a UserName rutiny Get-Credential . Tento formát příkazu je určený pro sdílené skripty a funkce. V tomto případě zpráva uživateli řekne, proč jsou potřeba přihlašovací údaje, a dává mu jistotu, že požadavek je legitimní.

Příklad 6

Invoke-Command -ComputerName Server01 {Get-Credential Domain01\User02}

PowerShell Credential Request : PowerShell Credential Request
Warning: This credential is being requested by a script or application on the SERVER01 remote computer.
Enter your credentials only if you trust the remote computer and the application or script requesting it.

Enter your credentials.
Password for user Domain01\User02: ***************

PSComputerName     : Server01
RunspaceId         : 422bdf52-9886-4ada-ab2f-130497c6777f
PSShowComputerName : True
UserName           : Domain01\User01
Password           : System.Security.SecureString

Tento příkaz získá přihlašovací údaje ze vzdáleného počítače Serveru01. Příkaz používá rutinu Invoke-CommandGet-Credential ke spuštění příkazu ve vzdáleném počítači. Výstup zobrazuje zprávu o vzdáleném zabezpečení, která Get-Credential obsahuje výzvu k ověření.

Parametry

-Credential

Určuje uživatelské jméno pro přihlašovací údaje, například User01 nebo Domain01\User01. Název -Credentialparametru je nepovinný.

Když příkaz odešlete a zadáte uživatelské jméno, zobrazí se výzva k zadání hesla. Pokud tento parametr vynecháte, zobrazí se výzva k zadání uživatelského jména a hesla.

Počínaje PowerShellem 3.0, pokud zadáte uživatelské jméno bez domény, Get-Credential už před název nevloží zpětné lomítko.

Přihlašovací údaje jsou uloženy v objektu PSCredential a heslo je uloženo jako SecureString.

Poznámka:

Další informace o ochraně dat SecureString naleznete v tématu Jak zabezpečený je SecureString?.

Type:PSCredential
Position:1
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Message

Určuje zprávu, která se zobrazí v výzvě k ověření. Tento parametr je určený pro použití ve funkci nebo skriptu. Pomocí zprávy můžete uživateli vysvětlit, proč požadujete přihlašovací údaje a jak se budou používat.

Tento parametr byl představen v PowerShellu 3.0.

Type:String
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Title

Nastaví text řádku nadpisu pro výzvu k ověření v konzole.

Tento parametr byl představen v PowerShellu 6.0.

Type:String
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-UserName

Určuje uživatelské jméno. Výzva k ověření požádá o heslo pro uživatelské jméno. Ve výchozím nastavení je uživatelské jméno prázdné a výzva k ověření vyžaduje uživatelské jméno i heslo.

Tento parametr byl představen v PowerShellu 3.0.

Type:String
Position:1
Default value:None (blank)
Required:False
Accept pipeline input:False
Accept wildcard characters:False

Vstupy

None

Do této rutiny nemůžete roušit objekty.

Výstupy

PSCredential

Tato rutina vrátí objekt přihlašovacích údajů.

Poznámky

Můžete použít objekt PSCredential , který Get-Credential se vytvoří v rutinách, které požadují ověření uživatele, například ty s parametrem Credential .

Parametr Credential není podporován všemi poskytovateli nainstalovanými pomocí PowerShellu. Počínaje PowerShellem 3.0 se podporuje u vybraných rutin, jako jsou rutiny Get-Content a New-PSDrive rutiny.