侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Python Paramiko模块的使用实际案例

Python  /  管理员 发布于 7年前   189

本文研究的主要是Python Paramiko模块的使用的实例,具体如下。

Windows下有很多非常好的SSH客户端,比如Putty。在python的世界里,你可以使用原始套接字和一些加密函数创建自己的SSH客户端或服务端,但如果有现成的模块,为什么还要自己实现呢。使用Paramiko库中的PyCrypto能够让你轻松使用SSH2协议。

Paramiko的安装方法网上有很多这样的帖子,这里就不描述了。这里主要讲如何使用它。Paramiko实现SSH2不外乎从两个角度实现:SSH客户端与服务端。

首先让我们理清以下几个名词:

  • SSHClient:包装了Channel、Transport、SFTPClient
  • Channel:是一种类Socket,一种安全的SSH传输通道;
  • Transport:是一种加密的会话(但是这样一个对象的Session并未建立),并且创建了一个加密的tunnels,这个tunnels叫做Channel;
  • Session:是client与Server保持连接的对象,用connect()/start_client()/start_server()开始会话。

具体请参考Paramiko的库文档:http://docs.paramiko.org/en/2.0/index.html

下面给出几个常用的使用案例:

SSH客户端实现方案一,执行远程命令

这个方案直接使用SSHClient对象的exec_command()在服务端执行命令,下面是具体代码:

  #实例化SSHClient  client = paramiko.SSHClient()  #自动添加策略,保存服务器的主机名和密钥信息  client.set_missing_host_key_policy(paramiko.AutoAddPolicy())  #连接SSH服务端,以用户名和密码进行认证  client.connect(ip,username=user,password=passwd)  #打开一个Channel并执行命令  stdin,stdout,stderr = client.exec_command(command)  #打印执行结果  print stdout.readlines()  #关闭SSHClient  client.close()

SSH客户端实现方案二,执行远程命令

这个方案是将SSHClient建立连接的对象得到一个Transport对象,以Transport对象的exec_command()在服务端执行命令,下面是具体代码:

#实例化SSHClientclient = paramiko.SSHClient()#自动添加策略,保存服务器的主机名和密钥信息client.set_missing_host_key_policy(paramiko.AutoAddPolicy())#连接SSH服务端,以用户名和密码进行认证client.connect(ip,username=user,password=passwd)#实例化Transport,并建立会话Sessionssh_session = client.get_transport().open_session()if ssh_session.active:  ssh_session.exec_command(command)  print ssh_session.recv(1024)client.close()

SSH服务端的实现

实现SSH服务端必须继承ServerInterface,并实现里面相应的方法。具体代码如下:

import socketimport sysimport threadingimport paramikohost_key = paramiko.RSAKey(filename='private_key.key')class Server(paramiko.ServerInterface):  def __init__(self):  #执行start_server()方法首先会触发Event,如果返回成功,is_active返回True    self.event = threading.Event()  #当is_active返回True,进入到认证阶段  def check_auth_password(self, username, password):    if (username == 'root') and (password == '123456'):      return paramiko.AUTH_SUCCESSFUL    return paramiko.AUTH_FAILED  #当认证成功,client会请求打开一个Channel  def check_channel_request(self, kind, chanid):    if kind == 'session':      return paramiko.OPEN_SUCCEEDED#命令行接收ip与portserver = sys.argv[1]ssh_port = int(sys.argv[2])#建立sockettry:  sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  #TCP socket  sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)  sock.bind((server, ssh_port))    sock.listen(100)    print '[+] Listening for connection ...'  client, addr = sock.accept()except Exception, e:  print '[-] Listen failed: ' + str(e)  sys.exit(1)print '[+] Got a connection!'try:  #用sock.accept()返回的socket实例化Transport  bhSession = paramiko.Transport(client)  #添加一个RSA密钥加密会话  bhSession.add_server_key(host_key)  server = Server()  try:  #启动SSH服务端    bhSession.start_server(server=server)  except paramiko.SSHException, x:    print '[-] SSH negotiation failed'  chan = bhSession.accept(20)   print '[+] Authenticated!'  print chan.recv(1024)  chan.send("Welcome to my ssh")  while True:    try:      command = raw_input("Enter command:").strip("\n")       if command != 'exit':        chan.send(command)        print chan.recv(1024) + '\n'      else:        chan.send('exit')        print 'exiting'        bhSession.close()        raise Exception('exit')    except KeyboardInterrupt:      bhSession.close()except Exception, e:  print '[-] Caught exception: ' + str(e)  try:    bhSession.close()  except:    pass  sys.exit(1)

使用SFTP上传文件

import paramiko#获取Transport实例tran = paramiko.Transport(("host_ip",22))#连接SSH服务端tran.connect(username = "username", password = "password")#获取SFTP实例sftp = paramiko.SFTPClient.from_transport(tran)#设置上传的本地/远程文件路径localpath="/root/Desktop/python/NewNC.py"remotepath="/tmp/NewNC.py"#执行上传动作sftp.put(localpath,remotepath)tran.close()

使用SFTP下载文件

import paramiko#获取SSHClient实例client = paramiko.SSHClient()client.set_missing_host_key_policy(paramiko.AutoAddPolicy())#连接SSH服务端client.connect("host_ip",username="username",password="password")#获取Transport实例tran = client.get_transport()#获取SFTP实例sftp = paramiko.SFTPClient.from_transport(tran)remotepath='/tmp/NewNC.py'localpath='/root/Desktop/NewNC.py'sftp.get(remotepath, localpath)client.close()

总结

以上就是本文关于Python Paramiko模块的使用实际案例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!


  • 上一条:
    python2.7到3.x迁移指南
    下一条:
    python中使用xlrd读excel使用xlwt写excel的实例代码
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客