如何自动化Powershell的交互式Get-Credential方法

44次阅读
没有评论

问题描述

想要编写一个Python脚本,用于自动化Powershell的Get-Credential方法。他尝试了一些代码,但是无法正确传递密码,出现了异常。他希望得到帮助。

解决方案

请注意以下操作注意版本差异及修改前做好备份。

方案1

你的Python脚本中的问题在于在命令后面添加了\n,而write方法已经自动添加了换行符。因此,你的脚本实际上执行了以下操作:

$cred = Get-Credential # 启动命令
# 下面这行是多余的,Get-Credential之后会忽略它,但你可以在输出中看到它。
Administrator # 发送到User:提示符
# 发送到Password:提示符
Password # 发送到shell输入,导致日志末尾的错误。

这种方法相对较为复杂,通常情况下,可以通过其他方式构建凭据对象,比如在这篇博客文章中描述的方法(以下是完整引用):

$password = "mypassword" | ConvertTo-SecureString -asPlainText -Force
$username = "nwtraders\administrator"
$credential = New-Object System.Management.Automation.PSCredential($username,$password)

然后可以像下面这样使用它:

Get-WMIObject win32_logicaldisk -ComputerName Server1 -Credential $credential

方案2

使用脚本或工具来管理容器的启动顺序可能会增加复杂性,并且需要确保容器A和容器B之间的依赖关系正确设置。

还有一种方法是编写脚本或使用工具来控制容器的运行顺序。你可以使用docker run命令来手动控制容器的启动顺序,或者使用一些第三方工具来管理容器的依赖关系。

以下是一个简单的bash脚本示例,可以在容器A启动后启动容器B:

#!/bin/bash
# 启动容器A
docker run -d --name container_a your_image_a
# 等待容器A完全启动
while ! docker exec container_a echo "Container A is ready"; do
  sleep 1
done
# 启动容器B
docker run -d --name container_b your_image_b

在这个示例中,我们首先使用docker run命令启动容器A,并将其命名为container_a。然后,使用一个循环来等待容器A完全启动(这里是通过在容器内运行echo命令来测试)。一旦容器A就绪,我们再使用docker run命令启动容器B,并将其命名为container_b

以上是两种解决方案,你可以根据自己的需求选择适合的方法。希望对你有帮助!

正文完