Python基于模块Paramiko实现SSHv2协议


Posted in Python onApril 28, 2020

简介:

ssh是一个协议,OpenSSH是其中一个开源实现,paramiko是Python的一个库,实现了SSHv2协议(底层使用cryptography)。

有了Paramiko以后,我们就可以在Python代码中直接使用SSH协议对远程服务器执行操作,而不是通过ssh命令对远程服务器进行操作。

由于paramiko属于第三方库,所以需要使用如下命令先行安装 :pip install paramiko

paramiko包含两个核心组件:SSHClient和SFTPClient。

SSHClient的作用类似于Linux的ssh命令,是对SSH会话的封装,该类封装了传输(Transport),通道(Channel)及SFTPClient建立的方法(open_sftp),通常用于执行远程命令。

SFTPClient的作用类似与Linux的sftp命令,是对SFTP客户端的封装,用以实现远程文件操作,如文件上传、下载、修改文件权限等操作。

# Paramiko中的几个基础名词:
1、Channel:是一种类Socket,一种安全的SSH传输通道;
2、Transport:是一种加密的会话,使用时会同步创建了一个加密的Tunnels(通道),这个Tunnels叫做Channel;
3、Session:是client与Server保持连接的对象,用connect()/start_client()/start_server()开始会话。

SSHClient常用的方法介绍

connect():实现远程服务器的连接与认证,对于该方法只有hostname是必传参数。

常用参数

hostname 连接的目标主机
port=SSH_PORT 指定端口
username=None 验证的用户名
password=None 验证的用户密码
pkey=None 私钥方式用于身份验证
key_filename=None 一个文件名或文件列表,指定私钥文件
timeout=None 可选的tcp连接超时时间
allow_agent=True, 是否允许连接到ssh代理,默认为True 允许
look_for_keys=True 是否在~/.ssh中搜索私钥文件,默认为True 允许
compress=False, 是否打开压缩

set_missing_host_key_policy():设置远程服务器没有在know_hosts文件中记录时的应对策略。目前支持三种策略:

设置连接的远程主机没有本地主机密钥或HostKeys对象时的策略,目前支持三种:

AutoAddPolicy 自动添加主机名及主机密钥到本地HostKeys对象,不依赖load_system_host_key的配置。即新建立ssh连接时不需要再输入yes或no进行确认

WarningPolicy 用于记录一个未知的主机密钥的python警告。并接受,功能上和AutoAddPolicy类似,但是会提示是新连接
RejectPolicy 自动拒绝未知的主机名和密钥,依赖load_system_host_key的配置。此为默认选项

exec_command():在远程服务器执行Linux命令的方法。

open_sftp():在当前ssh会话的基础上创建一个sftp会话。该方法会返回一个SFTPClient对象。

# 利用SSHClient对象的open_sftp()方法,可以直接返回一个基于当前连接的sftp对象,可以进行文件的上传等操作.
sftp = client.open_sftp()
sftp.put('test.txt','text.txt')
SSHClient常用的方法举例

1.基于用户名和密码登入方式

import paramiko
class param():
 def param_iko(self):
  #实例化SSHClient
  client = paramiko.SSHClient()
  #自动添加策略,保存服务器的主机名和密钥信息,如果不添加,那么不再本地know_hosts文件中记录的主机将无法连接
  client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
  #连接SSH服务端,以用户名和密码进行认证
  client.connect(hostname='192.168.1.200', port=22, username='root', password='a123')
  #打开一个Channel并执行命令
  stdin, stdout, stderr = client.exec_command('df -h ')
  #打印执行结果
  print(stdout.read().decode('utf-8'))
  #关闭SSHClient
  client.close()
if __name__=='__main__':
  param().param_iko()

通过公钥连接,前提是两台Linux可以互相连接

两台服务器需要ssh免秘钥登入

import paramiko
class param_my():
 def param_miyao(self):
  #配置私人密钥文件位置
  private = paramiko.RSAKey.from_private_key_file('/root/.ssh/id_rsa')
  #实例化SSHClient
  client = paramiko.SSHClient()
  #自动添加策略,保存服务器的主机名和密钥信息,如果不添加,那么不再本地know_hosts文件中记录的主机将无法连接
  client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
  #连接SSH服务端,以用户名和密码进行认证
  client.connect(hostname='192.168.1.250',port=22,username='root',pkey=private)
  #打开一个Channel并执行命令
  stdin, stdout, stderr = client.exec_command('df -h ')
  #打印执行结果
  print(stdout.read().decode('utf-8'))
  #关闭SSHClient
  client.close()
if __name__=='__main__':
  param_my().param_miyao()
[root@master test]# python3 a.py 
文件系统        容量 已用 可用 已用% 挂载点
/dev/mapper/rhel-root  27G  21G 6.8G  75% /
devtmpfs        977M   0 977M  0% /dev
tmpfs         993M   0 993M  0% /dev/shm
tmpfs         993M 9.1M 984M  1% /run
tmpfs         993M   0 993M  0% /sys/fs/cgroup
/dev/sr0        3.8G 3.8G   0 100% /mnt/cdrom
/dev/sda1       1014M 161M 854M  16% /boot
tmpfs         199M   0 199M  0% /run/user/0
tmpfs         199M  12K 199M  1% /run/user/42

跨服务器上传和下载文件

import os,sys
import paramiko
class get_putclass():
  def get_put(self):
   t = paramiko.Transport(('192.168.1.250',22))
   t.connect(username='root',password='a123')
   sftp = paramiko.SFTPClient.from_transport(t)   #前面部分是192.168.1.250 远程机器上的文件,后半部分是取到本地的路径和文件名
   sftp.get('/root/file/test.txt','/home/python/tmp/test/test.txt')   #前面部分是本机器上的文件,后半部分是远程机器上的文件路径和文件名
   sftp.put('/home/python/tmp/test/a.py','/root/file/a.py')
   t.close()
if __name__=='__main__':
  get_putclass().get_put()

通过秘钥来上传下载文件

import os,sys
import paramiko
class get_put_myao():
  def get_put_miyao(self):
   pravie_key_path = '/root/.ssh/id_rsa'
   key = paramiko.RSAKey.from_private_key_file(pravie_key_path)
   t = paramiko.Transport(('192.168.1.250',22))
   t.connect(username='root',pkey=key)
   sftp = paramiko.SFTPClient.from_transport(t)
   sftp.put('/home/python/tmp/test/b.py','/root/file/b.py') 
   sftp.get('/root/file/test.txt','/home/python/tmp/test/test.txt') 
   t.close()
if __name__=='__main__':
  get_put_myao().get_put_miyao()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Flask框架学习笔记(一)安装篇(windows安装与centos安装)
Jun 25 Python
简单介绍Python中的readline()方法的使用
May 24 Python
Python文件右键找不到IDLE打开项解决办法
Jun 08 Python
Python实现的朴素贝叶斯分类器示例
Jan 06 Python
PyQt弹出式对话框的常用方法及标准按钮类型
Feb 27 Python
Python生成指定数量的优惠码实操内容
Jun 18 Python
python-django中的APPEND_SLASH实现方法
Jun 21 Python
对Python3之方法的覆盖与super函数详解
Jun 26 Python
python爬虫 urllib模块发起post请求过程解析
Aug 20 Python
python实现提取COCO,VOC数据集中特定的类
Mar 10 Python
PyCharm 安装与使用配置教程(windows,mac通用)
May 12 Python
python套接字socket通信
Apr 01 Python
Python内置函数locals和globals对比
Apr 28 #Python
使用python实现CGI环境搭建过程解析
Apr 28 #Python
基于python连接oracle导并出数据文件
Apr 28 #Python
numpy库ndarray多维数组的维度变换方法(reshape、resize、swapaxes、flatten)
Apr 28 #Python
简单了解python shutil模块原理及使用方法
Apr 28 #Python
python脚本监控logstash进程并邮件告警实例
Apr 28 #Python
用Python在Excel里画出蒙娜丽莎的方法示例
Apr 28 #Python
You might like
DOTA2 6.87版本后新眼位详解攻略
2020/04/20 DOTA
IP攻击升级,程序改进以对付新的攻击
2010/11/23 PHP
php设计模式 Prototype (原型模式)代码
2011/06/26 PHP
php中的一些数组排序方法分享
2012/07/20 PHP
php求一个网段开始与结束IP地址的方法
2015/07/09 PHP
PHP模版引擎原理、定义与用法实例
2019/03/29 PHP
IE DOM实现存在的部分问题及解决方法
2009/07/25 Javascript
DOM Scripting中的图片切换[兼容Firefox]
2010/06/12 Javascript
IE6、IE7中setAttribute不支持class/for/rowspan/colspan等属性
2011/08/28 Javascript
CSS3实现动态背景登录框的代码
2015/07/28 Javascript
jQuery手机拨号界面特效代码分享
2015/08/27 Javascript
javascript给span标签赋值的方法
2015/11/26 Javascript
jquery正则表达式验证(手机号、身份证号、中文名称)
2015/12/31 Javascript
JS简单实现DIV相对于浏览器固定位置不变的方法
2016/06/17 Javascript
微信和qq时间格式模板实例详解
2016/10/21 Javascript
Node.js安装配置图文教程
2017/05/10 Javascript
Vue.js中 v-model 指令的修饰符详解
2018/12/03 Javascript
微信小程序模板template简单用法示例
2018/12/04 Javascript
操作按钮悬浮固定在微信小程序底部的实现代码
2019/08/02 Javascript
将RGB值转换为灰度值的简单算法
2019/10/09 Javascript
js 图片懒加载的实现
2020/10/21 Javascript
[36:52]DOTA2真视界:基辅特锦赛总决赛
2017/05/21 DOTA
[47:39]2018DOTA2亚洲邀请赛 3.31 小组赛 A组 LGD vs OPTIC
2018/03/31 DOTA
python文件比较示例分享
2014/01/10 Python
git进行版本控制心得详谈
2017/12/10 Python
python实现自主查询实时天气
2018/06/22 Python
Python实现基于socket的udp传输与接收功能详解
2019/11/15 Python
Pycharm中安装wordcloud等库失败问题及终端通过pip安装的Python库如何添加到Pycharm解释器中(推荐)
2020/05/10 Python
使用Keras建立模型并训练等一系列操作方式
2020/07/02 Python
Python用来做Web开发的优势有哪些
2020/08/05 Python
商务英语专业自荐信
2013/10/14 职场文书
护士实习鉴定范文
2013/12/22 职场文书
党员领导干部民主生活会批评与自我批评发言
2014/09/28 职场文书
清明节扫墓活动总结
2015/02/09 职场文书
2019暑期安全倡议书!
2019/06/27 职场文书
创业计划书之面包店
2019/09/12 职场文书