我需要能够在另一台服务器上运行命令。此脚本充当另一个在实际服务器上运行的脚本的引导程序。这适用于同一域上的服务器,但如果我需要在远程服务器上运行此脚本,我需要指定凭据。
该命令从Msbuild目标文件开始,如下所示:
<Target Name="PreDeployment" Condition="true" BeforeTargets="MSDeployPublish">
<Exec Command="powershell.exe -ExecutionPolicy Bypass invoke-command bootstrapScript.ps1 -computername $(MyServer) -argumentlist param1, param2" />
</Target>
但是,我需要能够通过创建一个带有安全密码的新PSCredentials对象来提供凭据,以便我的部署脚本在远程服务器上运行:
<Target Name="PreDeployment" Condition="true" BeforeTargets="MSDeployPublish">
<Exec Command="powershell.exe -ExecutionPolicy Bypass invoke-command bootstrapScript.ps1 -computername $(MyServer) -credential New-Object System.Management.Automation.PSCredential ('admin', (convertto-securestring $(Password) -asplaintext -force)) -argumentlist param1, param2" />
</Target>
当我运行构建时,会弹出一个对话框,其用户名设置为System.Management.Automation.PSCredential。 我需要能够在可执行目标上内联创建凭据。我该如何做到这一点?
答案 0 :(得分:3)
尝试将parens放在PSCredential对象的实例化周围,例如:
... -credential (New-Object System.Management.Automation.PSCredential 'admin',(convertto-securestring $(Password) -asplaintext -force)) -argumentlist param1, param2" />
PowerShell解析倾向于将参数解释为文字字符串(或数字)。如果要评估表达式,通常将表达式放在parens中。这在PowerShell中称为分组表达式。