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 / 问题 / 38825
Accepted
JohannesR
JohannesR
Asked: 2009-07-11 01:50:46 +0800 CST2009-07-11 01:50:46 +0800 CST 2009-07-11 01:50:46 +0800 CST

ssh 中类似 Bash 的命令替换或如何从 ssh *client* 请求内容?

  • 772

在 bash(和其他 shell)中,可以使用 $() 和 ``(反引号)之类的东西将命令的结果插入命令行。

现在,如果您有类似的东西,但对于 ssh 会话,那就太好了。因此,您处于 ssh 会话中,需要来自您自己计算机的一些信息,并希望将其放入您所连接计算机的内部命令行中。

例如说你想直接访问一个 mysql 控制台。你可以使用这样的命令:

ssh [email protected] "mysql -u blub -pmypass"

这行得通,但问题是,您可以在 ssh shell 进程的命令行中看到密码。

为了解决这个安全问题,我想要这样的东西:

ssh [email protected] "mysql -u blub -p\$(ssh-on-client 'cat pass-file')"

这将cat passfile在 ssh 客户端而不是服务器上执行。有没有这样的已知情况?你还有其他技巧可以做到这一点吗?

更新:我很欣赏引用我的例子的答案,但除非他们回答真正的问题,否则我不会接受它们。也就是说,是否可以从 ssh 会话中与 ssh 客户端计算机进行通信。(我知道这可能构成安全问题)

可能的解决方案:

  • 在客户端上有一个 ssh 服务器可以连接回来。(sweimann) 问题是如何获取连接回服务器的凭据。
  • 使用 ssh 创建隧道并使用一些 netcat 脚本/telnet 在服务器上执行命令并将结果发回。
  • 使用expect 编写shell 脚本。(扎克汤普森)
  • 在客户端上使用自定义包装器围绕 ssh 观察控制台并采取相应措施。(札幌)
  • 修补 SSH 以支持这一点。邮件列表上有类似的补丁可用。
  • ssh有一个选项“SendEnv”,它在远程计算机上设置环境变量。不过,这必须在远程 sshd 上启用。
bash ssh shell
  • 12 12 个回答
  • 6428 Views

12 个回答

  • Voted
  1. DarwinSurvivor
    2009-07-11T19:55:05+08:002009-07-11T19:55:05+08:00

    尝试使用 <。

    ssh [email protected] "mysql -u blub -p" <文件

    如果“文件”中的第一行是您的密码,它“应该”将其用于密码提示,那么其余的将用于 sql 部分。

    如果您只是在远程服务器上执行一个 sql 文件,请尝试:

    ssh [email protected] "mysql -u blub -p < file.sql" <密码

    • 5
  2. Best Answer
    Zac Thompson
    2009-07-11T18:46:28+08:002009-07-11T18:46:28+08:00

    您想为此使用期望。它可能已经在您的机器上。它是任何类型的交互式命令行自动化的标准工具。这是一个 Tcl 库,因此您将在此过程中免费获得一些 Tcl 技能。谨防; 这很容易上瘾。

    #!/path/to/expect
    spawn ssh [email protected] "mysql -u blub"
    expect "*ssword:*"
    send -- "mypass\r"
    interact
    
    • 3
  3. otto.poellath
    2009-07-15T03:10:22+08:002009-07-15T03:10:22+08:00

    几年前我一直在研究潜在的问题。我想从 SSH 会话中触发 SCP 下载。像您的问题一样,这需要从 SSH 会话内部与客户端上的某个进程进行通信。

    所以这是第三种可能的解决方案:使用 SSH 的包装器进行连接,它会扫描 SSH 的输出并在识别模式时在本地触发某些命令。这显然是一个黑客,但它可能会成功。

    我最终得到了 /usr/bin/script 的修改版本,它会记住我的 SSH 连接(例如me@somehost),并且每当我的 ssh 会话打印###/some/absulte/path/to/file/on/host.txt###时,它都会在本地执行scp me@somehost:/some/absulte/path/to/file/on/host.txt .

    一个简单的 shell 脚本用于方便地在服务器上生成模式和绝对路径。

    (我的代码实际上做了更多:它在下载的文件上打开了一个本地文本编辑器,并在文件被修改时使用 SCP 重新上传它。如果你想要代码,请告诉我。)

    从那以后,我一直在寻找一个更好的实现,但到目前为止还没有找到。

    也许这种技术可以实现为 SSH 代理命令(想想 connect.c),而不是 SSH 的包装器。

    • 2
  4. Sven
    2009-07-11T01:59:32+08:002009-07-11T01:59:32+08:00

    对于这个特定的问题,也许您可​​以将密码放在服务器上的~/my.cnf文件中?

    出于您的想法:您必须使用转义才能使其工作:

    ssh dba@db "echo \`ssh [email protected] \"cat echofile\" \`"
    

    再次编辑:您将需要从服务器到客户端的无密码登录,这意味着服务器上您的客户端框的私钥,这甚至比 my.cnf 更不安全。

    • 1
  5. lexsys
    2009-07-11T03:20:11+08:002009-07-11T03:20:11+08:00

    您必须模拟终端会话:

    ssh -t [email protected] "mysql -u blub -p"
    

    在这种情况下,您将被要求输入通过加密的 ssh 通道在网络中传输的密码,并且不会显示在控制台中。

    • 1
  6. rpetre
    2009-07-11T02:00:16+08:002009-07-11T02:00:16+08:00

    你需要先执行一个shell,比如

    ssh [email protected] bash -c 'mysql -u user -p$(cat /root/pass_file)'
    
    • 0
  7. nik
    2009-07-11T02:15:23+08:002009-07-11T02:15:23+08:00

    您使用ssh而不是telnet但仍然通过命令发送密码,以便在远程计算机上以明文形式自由执行(在ps列表中可见)。

    请通读这篇关于保护 MySQL 的 SecurityFocus 文章。

    • 0
  8. Sven
    2009-07-11T07:13:24+08:002009-07-11T07:13:24+08:00

    好的,我想我可以肯定地说你不想做的事情在一般情况下是不可能的,只有解决方法取决于你想要解决的实际问题。

    再考虑一下,我将解决您给出的“示例问题”,只需通过 ssh 从客户端到服务器进行端口转发,然后使用带有本地 my.cnf 的本地 mysql 客户端,这实际上是我总是使用mysql的方式。

    • 0
  9. Amandasaurus
    2009-07-16T05:39:08+08:002009-07-16T05:39:08+08:00

    您可以在本地计算机上使用环境变量。如果您本地计算机上的某人可以看到您的环境,它将打开安全漏洞。服务器上的任何人都可以看到密码。

    PASSWORD=$(cat pass-file) ssh [email protected] "mysql -u blub -p$PASSWORD"
    
    • 0
  10. Yan
    2009-07-21T09:50:57+08:002009-07-21T09:50:57+08:00

    我认为通过使用单引号,环境变量的值将从远程机器中获取。因此,您可以在远程机器上的 .bashrc 中设置 PASSWORD=value。然后在您的本地机器上运行 ssh [email protected] '。~/.bashrc; mysql -u blub -p$PASSWORD'

    • 0

相关问题

  • 在 Windows Server 2003 上通过 SSH 启动和停止 Mongrel 服务

  • 隧道 Xbox 网络流量 [关闭]

  • 在 .bashrc 中设置环境变量的最佳方法是什么?

  • 为什么使用authorized_keys通过ssh自动登录不起作用?

Sidebar

Stats

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

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +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