首页 > 系统相关 >linux之sshpass命令

linux之sshpass命令

时间:2023-02-10 16:46:55浏览次数:35  
标签:rumenz 密码 linux 命令 ssh sshpass 使用 SSH

将文件连接并传输到远程系统是系统管理员一直在做的事情。SSH是Linux平台上许多系统管理员使用的基本工具。SSH支持两种身份验证形式:

  • 1.密码认证
  • 2.公钥认证

公钥认证被认为是这两种方法中最安全的形式,尽管密码认证是最流行和最容易的。但是,使用密码验证时,总是要求用户输入密码。这种重复是乏味的。此外,SSH在外壳程序脚本中使用时也需要手动干预。如果在使用SSH密码身份验证时需要自动化,那么一个简单的工具sshpass必不可少。

什么是sshpass

sshpass 实用程序旨在使用键盘交互密码身份验证模式运行SSH ,但以非交互方式运行。

SSH使用直接TTY访问来确保密码确实是由交互式键盘用户发出的。sshpass在专用的TTY中运行SSH,让SSH认为它是从交互式用户那里获取密码的。

安装sshpass

您可以sshpass使用以下简单命令进行安装:

  1. > yum install sshpass -y

使用sshpass

sshpass选项之后指定要运行的命令。通常,该命令ssh带有参数,但也可以是任何其他命令。不过,目前SSH密码提示已硬编码为sshpass

  1. sshpass [-f filename | -d num | -p password | -e] [options]

命令选项

  1. -p 密码 密码在命令行中给出。
  2. -f 文件名 密码是文件名的第一行。
  3. -d number number是sshpass从运行程序继承的文件描述符。从打开的文件描述符中读取密码。
  4. -e 密码来自环境变量"SSHPASS"。

用于sshpass通过SSH登录到远程服务器。假设密码为4u2tryhack。以下是使用sshpass选项的几种方法。

使用-p(这是最不安全的选择,不应使用):

  1. > sshpass -p "4u2tryhack" ssh [email protected]

-p在shell脚本中使用时,该选项如下所示:

  1. > sshpass -p "4u2tryhack" ssh -o StrictHostKeyChecking=no [email protected]

使用-f选项(密码应该是文件名的第一行):

  1. > echo'4u2tryhack' > pass_file
  2. > chmod 0400 pass_file
  3. > sshpass -f pass_file ssh [email protected]

-f 在shell脚本中使用以下选项:

  1. > sshpass -f pass_file ssh -o StrictHostKeyChecking=no [email protected]

使用-e选项(密码应该是文件名的第一行)

  1. $ SSHPASS='4u2tryhack' sshpass -e ssh [email protected]

-e在shell脚本中使用时,该选项如下所示:

  1. > SSHPASS ='4u2tryhack' sshpass -e ssh -o StrictHostKeyChecking=no [email protected]

示例2:Rsync

sshpass搭配使用rsync

  1. > SSHPASS='4u2tryhack' rsync --rsh="sshpass -e ssh -l username" /rumenz/ rumenz.com:/opt/rumenz/

上面使用了-e选项,该选项将密码传递给环境变量SSHPASS

我们可以-f像这样使用开关:

  1. > rsync --rsh="sshpass -f pass_file ssh -l username" /rumenz/ rumenz.com:/opt/rumenz/

示例3:Scp

使用sshpassscp:

  1. > scp -r /var/www/html --rsh="sshpass -f pass_file ssh -l user" rumenz.com:/var/www/html

范例4:GPG

您也可以使用sshpassGPG加密的文件。使用该-f开关时,参考文件为纯文本格式。让我们看看如何使用GPG加密文件并使用它。

首先,创建一个文件,如下所示:

  1. > echo '4u2tryhack'> .sshpasswd

接下来,使用以下gpg命令加密文件:

  1. > gpg -c .sshpasswd

删除包含明文的文件:

  1. > rm .sshpasswd

最后,如下使用它:

  1. > gpg -d -q .sshpassword.gpg > pass_file; sshpass -f pass_file ssh [email protected]

标签:rumenz,密码,linux,命令,ssh,sshpass,使用,SSH
From: https://www.cnblogs.com/ponyton/p/17109481.html

相关文章

  • 查看linux系统是Ubuntu还是Centos
    前置小知识:一般来说著名的Linux系统基本上分两大类:RedHat 系列:Redhat、Centos、Fedora等Debian 系列:Debian、Ubuntu等 查看linux是centos还是ubuntu的方法以下......
  • Fiddler命令行常用命令以及常用快捷键
    1.?+字符:Fiddler会高亮所有URL匹配问号后面的字符的全部Session2.>size:选择响应尺寸大于指定大小的全部Session3.<size:选择响应尺寸大于指定大小的全部Session4.=status:......
  • jrtplib linux编译使用
    简介 JRTPLIB是一个用C++编写的面向对象的库,旨在帮助开发人员使用RFC3550中描述的实时传输协议(RTP),该库可以提供接口给开发者实现RTP发送和接收数据,而无需担心SSRC冲突、调......
  • top命令显示详解
    top命令输出信息太多不懂看?那是因为你没有看过这份总结!点击关注......
  • docker命令学习
    一篇学会使用docker(超详细)原创 艺说IT 艺说IT 2022-11-2615:07 发表于广西收录于合集#docker1个#容器技术1个#容器命令1个一、docker介绍Docker是......
  • linux篇-centos7.3配置
    Centos7.3防火墙配置1、查看firewall服务状态systemctlstatusfirewalld2、查看firewall的状态firewall-cmd--state3、开启、重启、关闭、firewalld.service服务开启s......
  • linux篇-公司网络故障那些事(路由器变交换机)
    首先这次网络故障是断电引起的我给大家画个模型三层的为八口交换机一层的为五口打印机笔记本代表两台无线打印机首先八口的连接了公司采购电脑一台,业务电脑一台,其他电......
  • linux篇-Centos7构建NFS服务器和连接
    准备两台centos7虚拟机192.168.30.133192.168.30.1292.192.168.30.1(服务端),3查看rpc服务是否启动4测试安装是否成功5修改配置文件vi/etc/exports/data192.168.1.0/24......
  • linux篇-centos7安装DHCP服务器
    1检查防火墙和selinux(关闭)关闭防火墙和selinux,这边不多说2检查DHCP状态3安装DHCP软件包4把系统默认的样例复制5修改配置文件optiondomain-name“example.org”;--DN......
  • linux篇-CentOS7搭建NTP服务器
    1查看服务器、客户端操作系统版本2查看服务器是否安装ntp3如果没有安装4安装完成后重新查看服务器是否安装ntp5查看ntp服务器状态6修改配置文件注释#server0.centos......