Aracılığıyla paylaş


Get-Credential

Kullanıcı adı ve parola temelinde bir kimlik bilgisi nesnesi alır.

Sözdizimi

CredentialSet EnterprisePublishing

Get-Credential
    [[-Credential] <PSCredential>]
    [<CommonParameters>]

MessageSet

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

Description

Get-Credential cmdlet'i, belirtilen kullanıcı adı ve parola için bir kimlik bilgisi nesnesi oluşturur. Kimlik bilgisi nesnesini güvenlik işlemlerinde kullanabilirsiniz.

Get-Credential cmdlet'i kullanıcıdan bir parola ya da kullanıcı adı ve parola talep eder. İstem için özelleştirilmiş bir ileti belirtmek üzere İleti parametresini kullanabilirsiniz.

Windows PowerShell 5.1 ve önceki sürümlerde Windows, kullanıcı adı ve parola istemeye yönelik bir iletişim kutusu sunar. PowerShell 6.0 ve sonraki sürümlerde, istem tüm platformlar için konsolunda sunulur.

Örnekler

Örnek 1

$c = Get-Credential

Bu komut bir kimlik bilgisi nesnesi alır ve $c değişkenine kaydeder.

Komutu girdiğinizde bir kullanıcı adı ve parola girmeniz istenir. İstenen bilgileri girdiğinizde, cmdlet kullanıcının kimlik bilgilerini temsil eden bir PSCredential nesnesi oluşturur ve $c değişkenine kaydeder.

Kimlik Bilgisi parametresine sahip olanlar gibi, kullanıcı kimlik doğrulaması isteyen cmdlet'lere giriş olarak nesnesini kullanabilirsiniz. Ancak, PowerShell ile yüklenen bazı sağlayıcılar Kimlik Bilgisi parametresini desteklemez.

Örnek 2

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

Bu örnek, etki alanı adı olmayan bir kullanıcı adı içeren bir kimlik bilgisi oluşturur.

İlk komut User01 kullanıcı adına sahip bir kimlik bilgisi alır ve $c değişkeninde depolar. İkinci komut, sonuçta elde edilen kimlik bilgisi nesnesinin Username özelliğinin değerini görüntüler.

Örnek 3

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

Bu komut PromptForCredential yöntemini kullanarak kullanıcıdan kullanıcı adını ve parolasını ister. komutu, elde edilen kimlik bilgilerini $Credential değişkenine kaydeder.

PromptForCredential yöntemi, Get-Credential cmdlet'ini kullanmaya alternatiftir. PromptForCredentialkullandığınızda, komut isteminde görüntülenen resim yazısını, iletileri ve kullanıcı adını belirtebilirsiniz.

Daha fazla bilgi için SDK'daki PromptForCredential belgelerine bakın.

Örnek 4

Bu örnekte, Get-Credentialtarafından döndürülenle aynı bir kimlik bilgisi nesnesinin nasıl oluşturulacağı gösterilmektedir.

$User = "Domain01\User01"
$PWord = Read-Host -Prompt 'Enter a Password' -AsSecureString
$credentialParams = @{
    TypeName = 'System.Management.Automation.PSCredential'
    ArgumentList = $User, $PWord
}
$Credential = New-Object @credentialParams

İlk komut kullanıcı adını $User değişkenine atar. Değerin "Domain\User" veya "ComputerName\User" biçimine uydığından emin olun.

İkinci komut, kullanıcı girişinden güvenli bir dize oluşturmak için Read-Host cmdlet'ini kullanır. İstemi parametresi kullanıcı girişini ister ve AsSecureString parametresi girişi maskeler ve güvenli bir dizeye dönüştürür.

Üçüncü komut, New-Object ve değişkenlerinde depolanan değerlerden bir $User nesnesi oluşturmak için $PWord cmdlet'ini kullanır.

Örnek 5

$credentialParams = @{
    Message = "Credential are required for access to the \\Server1\Scripts file share."
    UserName = "Server01\PowerUser"
}
Get-Credential @credentialParams
PowerShell Credential Request
Credential are required for access to the \\Server1\Scripts file share.
Password for user Server01\PowerUser:

Bu komut, cmdlet'in İleti ve Get-Credential parametrelerini kullanır. Bu komut biçimi paylaşılan betikler ve işlevler için tasarlanmıştır. Bu durumda, ileti kullanıcıya kimlik bilgilerinin neden gerekli olduğunu bildirir ve isteğin geçerli olduğuna güven verir.

Örnek 6

Invoke-Command -ComputerName Server01 -ScriptBlock {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

Bu komut, Server01 uzak bilgisayarından bir kimlik bilgisi alır. komut, uzak bilgisayarda bir Invoke-Command komutu çalıştırmak için Get-Credential cmdlet'ini kullanır. Çıktı, Get-Credential'ın kimlik doğrulama istemine dahil edilen uzak güvenlik mesajını gösterir.

Parametreler

-Credential

User01 veya Domain01\User01gibi kimlik bilgileri için bir kullanıcı adı belirtir. -Credentialparametre adı isteğe bağlıdır.

Komutu gönderip bir kullanıcı adı belirttiğinizde parola girmeniz istenir. Bu parametreyi atlarsanız kullanıcı adı ve parola girmeniz istenir.

PowerShell 3.0'dan itibaren, bir kullanıcı adını etki alanı olmadan girerseniz Get-Credential artık adın önüne ters eğik çizgi eklemez.

Kimlik bilgileri bir PSCredential nesnesinde depolanır ve parola SecureStringolarak depolanır.

Uyarı

SecureString veri koruması hakkında daha fazla bilgi için bkz. SecureString ne kadar güvenli?.

Parametre özellikleri

Tür:PSCredential
Default value:None
Joker karakterleri destekler:False
DontShow:False

Parametre kümeleri

CredentialSet
Position:1
Zorunlu:False
İşlem hattından gelen değer:False
Özellik adına göre işlem hattından gelen değer:False
Kalan bağımsız değişkenlerden elde edilen değer:False

-Message

Kimlik doğrulama isteminde görüntülenen bir iletiyi belirtir. Bu parametre bir işlevde veya betikte kullanılmak üzere tasarlanmıştır. Kullanıcıya neden kimlik bilgileri istediğinizi ve bunların nasıl kullanılacağını açıklamak için iletiyi kullanabilirsiniz.

Bu parametre PowerShell 3.0'da kullanıma sunulmuştur.

Parametre özellikleri

Tür:String
Default value:None
Joker karakterleri destekler:False
DontShow:False

Parametre kümeleri

MessageSet
Position:Named
Zorunlu:False
İşlem hattından gelen değer:False
Özellik adına göre işlem hattından gelen değer:False
Kalan bağımsız değişkenlerden elde edilen değer:False

-Title

Konsolunda kimlik doğrulaması istemi için başlık satırının metnini ayarlar.

Bu parametre PowerShell 6.0'da kullanıma sunulmuştur.

Parametre özellikleri

Tür:String
Default value:None
Joker karakterleri destekler:False
DontShow:False

Parametre kümeleri

MessageSet
Position:Named
Zorunlu:False
İşlem hattından gelen değer:False
Özellik adına göre işlem hattından gelen değer:False
Kalan bağımsız değişkenlerden elde edilen değer:False

-UserName

Bir kullanıcı adı belirtir. Kimlik doğrulama istemi, kullanıcı adı için bir parola ister. Varsayılan olarak, kullanıcı adı boş olur ve kimlik doğrulama istemi hem kullanıcı adı hem de parola ister.

Bu parametre PowerShell 3.0'da kullanıma sunulmuştur.

Parametre özellikleri

Tür:String
Default value:None (blank)
Joker karakterleri destekler:False
DontShow:False

Parametre kümeleri

MessageSet
Position:1
Zorunlu:False
İşlem hattından gelen değer:False
Özellik adına göre işlem hattından gelen değer:False
Kalan bağımsız değişkenlerden elde edilen değer:False

CommonParameters

Bu cmdlet yaygın parametreleri destekler: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutBuffer, -OutVariable, -PipelineVariable, -ProgressAction, -Verbose, -WarningAction ve -WarningVariable. Daha fazla bilgi için bkz. about_CommonParameters.

Girişler

None

Nesneleri bu cmdlet'e yöneltemezsiniz.

Çıkışlar

PSCredential

Bu cmdlet bir kimlik bilgisi nesnesi döndürür.

Notlar

Get-Credential parametresine sahip olanlar gibi kullanıcı kimlik doğrulaması isteyen cmdlet'lerde oluşturduğu PSCredential nesnesini kullanabilirsiniz.

Kimlik Bilgisi parametresi, PowerShell ile yüklenen tüm sağlayıcılar tarafından desteklenmez. PowerShell 3.0'dan başlayarak, Get-Content ve New-PSDrive cmdlet'leri gibi belirli cmdlet'lerde desteklenir.