我正在使用通过PowerShell发送的ADSI命令自动更改远程Invoke-Command目标上的密码。我使用以下PowerShell命令将ADSI命令发送到远程计算机:
Invoke-Command -ComputerName $computer -ScriptBlock {
(([ADSI]“WinNT://localhost/Administrator”).SetPassword($new_password)).SetInfo
} -Credential $mycred除了$new_password变量之外,一切都正常工作。如果我直接在ADSI命令中输入一个字符串(在SetPassword()方法中),则在远程客户机上成功地更改了密码。但是,如果我使用$new_password变量,则远程客户端上的管理员密码设置为空。所有其他变量,例如$computer和$mycred,似乎在整个Invoke-Command命令中正常工作,但是只有一个$new_password不能工作。即使我做了以下事情:
$new_password = "mypassword"
Invoke-Command -ComputerName $computer -ScriptBlock {
(([ADSI]“WinNT://localhost/Administrator”).SetPassword($new_password)).SetInfo
} -Credential $mycred发布于 2017-03-14 04:22:49
将变量传递到scriptblock应该如下所示:
$new_password = "mypassword"
Invoke-Command -ComputerName $computer -Credential $mycred -ScriptBlock {param($new_password) (([ADSI]“WinNT://localhost/Administrator,user”).SetPassword($new_password)).SetInfo } -argumentlist $new_password而adsi应该是([ADSI]“WinNT://localhost/Administrator,user”)
https://stackoverflow.com/questions/42776908
复制相似问题