Use current Powershell credentials for remote call

后端 未结 2 1937
Happy的楠姐
Happy的楠姐 2021-01-27 06:41

I have a Powershell script that is used to remotely call other Powershell scripts on other servers. The script is used to shut down and start up services on the different serve

2条回答
  •  有刺的猬
    2021-01-27 07:11

    The -Credential method on Invoke-Command is probably what you want. I find this pretty useful for storing a credential set for scripting use in an encrypted fashion.

    Add-Type -assembly System.Security
    
    # String to Crypt
    $passwordASCII = Read-Host -Prompt "Enter the Password"
    
    # String to INT Array
    $enc = [system.text.encoding]::Unicode
    $clearPWD_ByteArray = $enc.GetBytes( $passwordASCII.tochararray())
    
    # Crypting
    $secLevel = [System.Security.Cryptography.DataProtectionScope]::LocalMachine
    $bakCryptedPWD_ByteArray = [System.Security.Cryptography.ProtectedData]::Protect($clearPWD_ByteArray, $null, $secLevel)
    
    # Store in Base 64 form
    $B64PWD_ByteArray = [Convert]::ToBase64String($bakCryptedPWD_ByteArray)
    Set-Content -LiteralPath c:\Temp\pass.txt -Value $B64PWD_ByteArray
    
    <#>
    Use...
    Add-Type -assembly System.Security
    $resCryptedPWD_ByteArray = [Convert]::FromBase64String((Get-Content -LiteralPath "$Password_File"))
    $secLevel = [System.Security.Cryptography.DataProtectionScope]::LocalMachine
    $clearPWD_ByteArray = [System.Security.Cryptography.ProtectedData]::Unprotect( $resCryptedPWD_ByteArray, $null, $secLevel )
    $enc = [system.text.encoding]::Unicode
    
    ...To retrieve the password from $Password_File
    
    Then use...
    
    $enc.GetString($clearPWD_ByteArray)
    
    ...As your password
    
    

提交回复
热议问题