AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1151573
Accepted
Mario Jost
Mario Jost
Asked: 2024-01-16 16:23:49 +0800 CST2024-01-16 16:23:49 +0800 CST 2024-01-16 16:23:49 +0800 CST

使用本机 powershell 脚本通过 SSH 远程运行命令

  • 772

我们希望通过 SSH 从 powershell 脚本中在网络设备上运行命令。我知道我们可以这样做:

ssh [email protected]

但这是交互式的,需要您接受 RSA 密钥到您的已知主机和其他内容中。所以我们过去使用 PoshSSH 作为一个模块来实现我们的目标。但是我们在 PoshSSH 方面遇到了一些问题,并且想知道这么多年之后,powershell 中是否有一个本地解决方案可以在不安装模块的情况下实现相同的结果?

ssh
  • 2 2 个回答
  • 73 Views

2 个回答

  • Voted
  1. Best Answer
    u1686_grawity
    2024-01-16T19:21:25+08:002024-01-16T19:21:25+08:00

    但这是交互式的,需要您接受 RSA 密钥到您的已知主机和其他内容中。

    假设这些设备不是全新的开箱即用,它们的 RSA 主机密钥将是静态的,这意味着您可以(而且我认为应该)保留脚本可以使用的持久的known_hosts 文件。

    收集所有设备的主机密钥(ssh-keyscan如果需要的话使用),将文件放在网络共享上(或脚本旁边),用于ssh -o GlobalKnownHostsFile=让每个人的脚本访问它。

    (主机密钥是一种安全措施 - 如果您的脚本只是盲目地将密码发送到任何未知设备,那么如何阻止某人用收集其收到的密码的设备替换设备,并获得对网络中所有此类设备的访问权限?)

    交互性的另一个来源是密码输入,但这也可以使用上传到所有设备的 RSA 用户密钥对来解决。

    powershell 中是否有一个本地解决方案可以在不安装模块的情况下实现相同的结果?

    不; 微软选择将 OpenSSH 与 Windows 捆绑在一起,而不是创建自己的 SSH 客户端实现 - 甚至 PSRemoting-over-SSH 也使用该ssh程序。

    • 4
  2. symcbean
    2024-01-16T19:30:15+08:002024-01-16T19:30:15+08:00

    但这是交互式的,需要您接受 RSA 密钥到您的已知主机和其他内容中

    你读过说明书吗?。MS-Windows 上的命令ssh是 openssh 客户端,它提供了巨大的灵活性。如果您不希望它验证主机密钥,请告诉它不要验证主机密钥。如果要在 ssh 会话中运行特定命令,请指定要在 ssh 会话中运行的命令。

    ssh -o StrictHostKeyChecking=no [email protected] pwd
    
    • 3

相关问题

  • 如何最好地设置 ssh 隧道以访问远程网络 (Linux)

  • SSH 和重定向

  • 通过 SSH 会话使用 NET USER 命令拒绝访问

  • SSH 服务器零日漏洞利用 - 保护自己的建议

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve