使用winrm远程连接windows,并执行cmd

本文详细介绍如何使用WinRM服务实现Windows系统的远程控制与命令执行。包括查找IP地址、启动WinRM服务、配置认证及加密方式等关键步骤,并提供Python示例代码用于测试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用winrm远程连接windows,并执行cmd

首先需要找到要远程控制的ip,被控机与控制机需要在一个局域网

1.在被控机的cmd中执行ipconfig/all可以找到被控机的ip

2.可以利用ip尝试是否可以ping通,执行ping ip(目标机的ip) -t-t是为了一直显示ping的结果,直至按键盘上的ctrl+C终止,也可以在命令行不加-t

3.需要在被控机上启动winrm服务,首先执行 winrm quickconfig启动服务,这里会出现是否执行更改,直接输入Y即可。但同时可能会遇到一些问题:
(1)拒绝访问:可以重新以管理员身份进入cmd
(2)提示需要将网络由公用改为域或专用:直接在网络设置中找到以太网将公用改为专用即可

4.执行winrm e winrm/config/listener查看监听端口等信息

5.执行winrm set winrm/config/service/auth @{ Basic="true"},为winrm service 配置auth

6.执行 winrm set winrm/config/service@{AllowUnencrypted="true"} ,为winrm service 配置加密方式为允许非加密
注意:如果以上两个命令执行会报错,错误: Invalid use of command line. Type “winrm -?” for help.需要在@{Basic=“true”}外部加单引号’才可以

7.winrm get winrm/config,查看

8.启动/关闭winrm服务命令:net start/stop winrm
通过以上步骤winrm服务启动完成,可以正常使用

9.可以通过以下代码测试

import winrm
# 虚机服务器server 2019
IP_LOCAL = '192.168.0.112'        # 服务器IP
PWD_LOCAL = '123456'              # 服务器管理员密码

# 测试的命令
CMD = [
    'mkdir win_test_file',
    'mkdir win_test_file1'
]
def run_cmd(ip, user, pwd, cmd_list):
    try:
        win = winrm.Session('http://' + ip + ':5985/wsman', auth=(user, pwd))
        for cmd in cmd_list:
            ret = win.run_ps(cmd)
            if ret.status_code == 0:  # 调用成功
                print(cmd)
            else:
                return False
        return True
    except Exception as e:
        print(e)
# 测试命令执行
run_cmd(IP_LOCAL, 'administrator', PWD_LOCAL, CMD)

10.如果在运行过程中报错:the specified credentials were rejected by the server,可能是账号密码的问题
我在执行过程中报错,尝试很多办法都不行,最后发现之前administrator密码为空。改为123456以后就能正确执行
参考:https://my.oschina.net/randolphcyg/blog/4676004
https://blog.csdn.net/apollo_miracle/article/details/102754631?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.control&dist_request_id=&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.control

### 如何在 Windows 系统中通过远程命令行运行 Maven 命令 要在 Windows 上通过远程 CMD 执行 `mvn` 命令,可以利用多种方法实现这一目标。以下是几种常见的解决方案: #### 方法一:使用 PowerShell 的 Invoke-Command PowerShell 提供了一个强大的 cmdlet——`Invoke-Command`,可以通过它连接远程计算机执行命令。 ```powershell Invoke-Command -ComputerName RemotePC -ScriptBlock { & mvn --version } ``` 上述脚本会向名为 `RemotePC` 的远程主机发送请求,在其上执行 `mvn --version` 命令[^1]。为了成功运行此命令,需满足以下条件: - 远程计算机已启用 WinRM (Windows Remote Management) 正在监听传入的请求。 - 当前用户具有足够的权限访问远程机器上的资源。 #### 方法二:借助 PsExec 工具 Sysinternals 提供了一款实用的小型工具叫做 **PsExec**,允许管理员无需手动登录即可启动进程于其他系统之上。 下载地址通常位于微软官方网站或者其镜像站点。假设已经将 psexec.exe 放置到了当前目录下,则可如下操作: ```batch psexec \\RemotePC mvn --version ``` 这条指令会让 psexec 负责处理与 'RemotePC' 的通信细节, 同时在那里发起 mvn 版本查询动作. #### 方法三:配置 SSH 服务通过 SSH 客户端调用 虽然传统意义上SSH更多关联Linux环境,但在现代版Windows Server以及部分桌面版本里也支持内置OpenSSH服务器功能. 一旦激活了 OpenSSH Sever,在客户端就可以采用标准ssh语法来进行交互比如: ```bash ssh user@RemotePC "mvn --version" ``` 这一步骤假定你已经在目标节点设置了适当的身份验证机制(密码/密钥). --- 下面给出一段简单的 Java 类用来演示如何从程序内部触发外部 shell 操作从而间接达到相同效果: ```java public class RunMvnRemotely { public static void main(String[] args){ try{ Process process = Runtime.getRuntime().exec("cmd /c start powershell \"Invoke-Command -ComputerName RemotePC -ScriptBlock {& mvn --version}\""); int exitVal = process.waitFor(); System.out.println("Exited with error code "+exitVal); } catch(Exception e ){ e.printStackTrace(); } } } ``` 注意这里的例子仅作为概念证明用途实际生产环境中应当考虑安全性因素如加密传输通道等措施[^3]. ---
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wavehaha

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值