26

我正在尝试将 powershell 代码从我的计算机运行到我计算机上的 vm,但我不断收到此错误:

连接到远程服务器失败并显示以下错误消息:WinRM 客户端无法处理请求。如果身份验证方案与 Kerberos 不同,或者客户端计算机未加入域,则必须使用 HTTPS 传输或将目标计算机添加到 TrustedHosts 配置设置。使用 winrm.cmd 配置 TrustedHosts。请注意,TrustedHosts 列表中的计算机可能未经过身份验证。您可以通过运行以下命令获得更多信息:winrm help config。有关详细信息,请参阅 about_Remote_Troubleshooting 帮助主题。

我的代码:

  string runasUsername = @"\aaa";
    string runasPassword = "aaa";
    SecureString ssRunasPassword = new SecureString();
    foreach (char x in runasPassword)
        ssRunasPassword.AppendChar(x);
    PSCredential credentials = new PSCredential(runasUsername, ssRunasPassword);

    var connInfo = new WSManConnectionInfo(new Uri("http://10.0.5.35/PowerShell"),
        "http://schemas.microsoft.com/powershell/Microsoft.Exchange",credentials);
    connInfo.AuthenticationMechanism = AuthenticationMechanism.Basic;

    var runspace = RunspaceFactory.CreateRunspace(connInfo);


    var domainName = "domainName.COM";
    var password = "ActiveDirectoryPassword1234";
    var ssPassword = new SecureString();
    foreach (char c in password)
        ssPassword.AppendChar(c);


    var command = new Command("New-Mailbox");

    command.Parameters.Add("FirstName", firstName);
    command.Parameters.Add("LastName", lastName);
    command.Parameters.Add("Password", ssPassword);
    command.Parameters.Add("ResetPasswordOnNextLogon", false);
    command.Parameters.Add("OrganizationalUnit", "NeumontStudents");

    runspace.Open(); <--//error here
    var pipeline = runspace.CreatePipeline();
    pipeline.Commands.Add(command);


    var results = pipeline.Invoke();

    runspace.Dispose();

我错过了什么?

4

3 回答 3

34

如果客户端和远程计算机不在同一个域中,您有以下两种选择之一:

  • 使用 HTTPS 作为传输协议
  • 将远程计算机添加到客户端上的受信任主机列表中

为了将WinRM 配置为使用 HTTPS,请在两台机器上以管理员身份打开 PowerShell 控制台并运行:

winrm quickconfig -transport:https

并在防火墙上打开端口 5986:

netsh firewall add portopening TCP 5986 "WinRM over HTTPS"

或者,您可以通过运行以下命令将远程计算机添加为客户端上的受信任主机:

winrm set winrm/config/client @{TrustedHosts="10.0.5.35"}
于 2013-04-15T08:10:49.567 回答
2

你在两台机器上都启用了winrm吗?尝试winrm quickconfig在每台机器上运行以确保启用远程连接。

于 2013-04-15T08:03:44.303 回答
0

在新客户端上设置它,我必须:

  1. 以管理员身份运行 PowerShell

  2. 通过运行此命令并对提示回答“是”来启用 WinRM:

    winrm quickconfig
    
  3. 将主机添加到我信任的主机(1.2.3.4主机的 IP 地址在哪里):

    Set-Item wsman:localhost\client\trustedhosts -value 1.2.3.4
    
于 2022-02-11T12:18:24.853 回答