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

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

使用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

相关推荐

电脑关不了机?5招教你轻松解决烦恼!
365bet足球即时比分网

电脑关不了机?5招教你轻松解决烦恼!

📅 09-26 👁️ 6440
周枫先生:学习奇门遁甲,该看哪些书?
365体育怎么打不开网址

周枫先生:学习奇门遁甲,该看哪些书?

📅 08-05 👁️ 3293