linux 之 sshpass 命令
将文件连接并传输到远程系统是系统管理员一直在做的事情。SSH 是 Linux 平台上许多系统管理员使用的基本工具。SSH 支持两种身份验证形式:
1.密码认证
2.公钥认证
公钥认证被认为是这两种方法中最安全的形式,尽管密码认证是最流行和最容易的。但是,使用密码验证时,总是要求用户输入密码。这种重复是乏味的。此外,SSH 在外壳程序脚本中使用时也需要手动干预。如果在使用 SSH 密码身份验证时需要自动化,那么一个简单的工具
sshpass
必不可少。
什么是 sshpass
该
sshpass
实用程序旨在使用键盘交互密码身份验证模式运行 SSH ,但以非交互方式运行。
SSH 使用直接 TTY 访问来确保密码确实是由交互式键盘用户发出的。
sshpass
在专用的 TTY 中运行 SSH,让 SSH 认为它是从交互式用户那里获取密码的。
安装 sshpass
您可以
sshpass
使用以下简单命令进行安装:
使用 sshpass
在
sshpass
选项之后指定要运行的命令。通常,该命令ssh
带有参数,但也可以是任何其他命令。不过,目前 SSH 密码提示已硬编码为sshpass
。
命令选项
用于sshpass
通过 SSH 登录到远程服务器。假设密码为4u2tryhack
。以下是使用 sshpass 选项的几种方法。
使用
-p
(这是最不安全的选择,不应使用):
-p
在 shell 脚本中使用时,该选项如下所示:
使用-f
选项(密码应该是文件名的第一行):
-f
在 shell 脚本中使用以下选项:
使用-e
选项(密码应该是文件名的第一行)
-e
在 shell 脚本中使用时,该选项如下所示:
示例 2:Rsync
sshpass
搭配使用rsync
:
上面使用了
-e
选项,该选项将密码传递给环境变量 SSHPASS
我们可以-f
像这样使用开关:
示例 3:Scp
使用sshpass
与scp:
范例 4:GPG
您也可以使用
sshpass
GPG 加密的文件。使用该-f
开关时,参考文件为纯文本格式。让我们看看如何使用 GPG 加密文件并使用它。
首先,创建一个文件,如下所示:
接下来,使用以下
gpg
命令加密文件:
删除包含明文的文件:
最后,如下使用它:
原文链接:https://rumenz.com/rumenbiji/linux-sshpass.html微信公众号:入门小站
版权声明: 本文为 InfoQ 作者【入门小站】的原创文章。
原文链接:【http://xie.infoq.cn/article/c73d5854ed0e7cbcb5bb613f7】。文章转载请联系作者。
评论