基于Python实现ssh兼sftp客户端

 

by:授客 QQ:1033553122

实现功能

实现ssh客户端兼ftp客户端:实现远程连接,执行linux命令,上传下载文件

测试环境

Win7 64位

Python 3.3.4

paramiko 1.15.2

下载地址:

https://pypi.python.org/pypi/paramiko/1.15.2

https://pan.baidu.com/s/1i4SJ1CL

cryptography-1.0-cp34-none-win_amd64.whl

(如果paramiko可以正常安装完,则不需要安装该类库)

下载地址:

https://pypi.python.org/pypi/cryptography/1.0

https://pan.baidu.com/s/1jIRBJvg

安装好后,找到nt.py(本例中路径为:

Lib\site-packages\pycrypto-2.6.1-py3.4-win-amd64.egg\Crypto\Random\OSRNG\nt.py),修改

import winrandom

from Crypto.Random.OSRNG import winrandom

如下

#import winrandom

from Crypto.Random.OSRNG import winrandom

以解决ImportError: No module named 'winrandom'错误

VS2010

因操作系统而异,可能需要安装VS2010,以解决包依赖问题

代码实践


mysshclient.py


 


#!/usr/bin/env/ python

#
-*- coding:utf-8 -*-


__author__
=
'shouke'


import

os
from

paramiko.client
import

AutoAddPolicy
from

paramiko.client
import

SSHClient
from

otherTools
import

OtherTools

class

MySSHClient:
    def

__init__(self):
        self.ssh_client
= SSHClient()

#
连接登录

    def

connect(self,
hostname, port, username, password):
        try:
            print('正在远程连接主机:%s'

% hostname)
            self.ssh_client.set_missing_host_key_policy(AutoAddPolicy())
            self.ssh_client.connect(hostname=hostname,

port=port,

username=username,

password=password)
            return

[True,

''
]
        except

Exception
as

e:
            print('连接出错了%s'

% e)
            return

[False,

'%s'

% e]

#
远程执行命令

    def

exec_command(self,
command):
        try:
            print('正在执行命令:'+
command)
            stdin,
stdout, stderr =
self.ssh_client.exec_command(command)
            print('命令输出:')
            print(stdout.read())

# 读取命令输出

            return

[True,

tuple]
        except

Exception
as

e:
            print('执行命:%s令出错'

% command)
            return

[False,'%s'

% e]

#
下载文件(非目录文件)

    def

download_file(self,
remotepath, localpath):
        try:
            localpath
= os.path.abspath(localpath)
            localpath
= localpath.replace('\t',

'/t'
).replace('\n',

'/n'
).replace('\r',

'/r'
).replace('\b',

'/b'
)

# 转换特殊字符

            localpath
= localpath.replace('\f',

'/f'
)
            print('转换后的本地目标路径为:%s'

% localpath)
            head,
tail = os.path.split(localpath)
            if
not

tail:
                print('下载文件:%s
到本地:%s失败,本地文件名不能为空'

% (remotepath, localpath))
                return

[False,

'下载文件:%s
到本地:%s失败,本地文件名不能为空'

% (remotepath, localpath)]
            if
not

os.path.exists(head):
                print('本地路径:%s不存在,正在创建目录'

% head)
                OtherTools().mkdirs_once_many(head)

sftp_client
=
self.ssh_client.open_sftp()
            print('正在下载远程文件:%s
到本地:%s'

% (remotepath, localpath))
            sftp_client.get(remotepath,
localpath)
            sftp_client.close()
            return

[True,

''
]
        except

Exception
as

e:
            print('下载文件:%s
到本地:%s
出错:%s'

% (remotepath, localpath, e))
            return

[False,

'下载文件:%s
到本地:%s
出错:%s'

% (remotepath, localpath, e)]

#
上传文件(非目录文件)

    def

upload_file(self,
localpath, remotepath):
        try:
            localpath
= localpath.rstrip('\\').rstrip('/')
            localpath
= localpath.replace('\t',

'/t'
).replace('\n',

'/n'
).replace('\r',

'/r'
).replace('\b',

'/b'
)

# 转换特殊字符

            localpath
= localpath.replace('\f',

'/f'
)
            localpath
= os.path.abspath(localpath)
            print('转换后的本地文件路径为:%s'

% localpath)

remotepath
= remotepath.rstrip('\\').rstrip('/')
            head,
tail = os.path.split(localpath)
            if
not

tail:
                print('上传文件:%s
到远程:%s失败,本地文件名不能为空'

% (localpath, remotepath))
                return

[False,

'上传文件:%s
到远程:%s失败,本地文件名不能为空'

% (localpath, remotepath)]
            if
not

os.path.exists(head):
                print(

'上传文件:%s
到远程:%s失败,父路径不存在'

% (localpath, remotepath, head))
                return

[False,

'上传文件:%s
到远程:%s失败,父路径不存在'

% (localpath, remotepath, head)]

if
not

(remotepath.startswith('/')

or

remotepath.startswith('.')):
                print('上传文件:%s
到远程:%s失败,远程路径填写不规范%s'

% (localpath, remotepath,remotepath))
                return

[False,

'上传文件:%s
到远程:%s失败,远程路径填写不规范%s'

% (localpath, remotepath,remotepath)]
            sftp_client
=
self.ssh_client.open_sftp()
            head,
tail = os.path.split(remotepath)

head
= sftp_client.normalize(head)
# 规范化路径

            remotepath
= head +
'/'

+ tail
            print('规范化后的远程目标路径:',
remotepath)

print('正在上传文件:%s
到远程:%s'

% (localpath, remotepath))
            sftp_client.put(localpath,
remotepath)
            sftp_client.close()
            return

[True,

''
]
        except

Exception
as

e:
            print('上传文件:%s
到远程:%s
出错:%s'

% (localpath, remotepath, e))
            return

[False,

'上传文件:%s
到远程:%s
出错:%s'

% (localpath, remotepath, e)]

def

close(self):
        self.ssh_client.close()

Python 基于Python实现的ssh兼sftp客户端(下)

Python 基于Python实现的ssh兼sftp客户端(上)的更多相关文章

  1. Python 基于Python实现的ssh兼sftp客户端(下)

    基于Python实现的ssh兼sftp客户端   by:授客 QQ:1033553122 otherTools.py #!/usr/bin/env/ python # -*- coding:utf-8 ...

  2. Python 基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现

    基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现   by:授客 QQ:1033553122 测试环境 功能需求 实现思路 代码实践(关键技术点实现) 代码模块组织 ...

  3. Python 基于python操纵zookeeper介绍

    基于python操纵zookeeper介绍 by:授客  QQ:1033553122 测试环境 Win7 64位 Python 3.3.4 kazoo-2.6.1-py2.py3-none-any.w ...

  4. Python 基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控

    基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控   By: 授客 QQ:1033553122   1.测试环境 python 3.4 zookeeper- ...

  5. Python 基于Python从mysql表读取千万数据实践

    基于Python 从mysql表读取千万数据实践   by:授客 QQ:1033553122 场景:   有以下两个表,两者都有一个表字段,名为waybill_no,我们需要从tl_waybill_b ...

  6. Python基于Python实现批量上传文件或目录到不同的Linux服务器

    基于Python实现批量上传文件或目录到不同的Linux服务器   by:授客 QQ:1033553122 实现功能 1 测试环境 1 使用方法 1 1. 编辑配置文件conf/rootpath_fo ...

  7. Python 基于python编写一些算法程序等

    基于python编写一些算法程序等 by:授客 QQ:1033553122 QQ群:7156436 没特意去研究,只是这对群友在QQ群里(7156436)提出的一些小程序实现.编程题,算法.问题等,本 ...

  8. Python 基于python+mysql浅谈redis缓存设计与数据库关联数据处理

    基于python+mysql浅谈redis缓存设计与数据库关联数据处理 by:授客  QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3 ...

  9. Python 基于python操纵redis入门介绍

    基于python操纵redis入门介绍 by:授客  QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3.3.2 基于Python操作R ...

随机推荐

  1. Spring lazy-init 原理分析

    普通的bean的初始化是在容器启动初始化阶段执行的,而被lazy-init修饰的bean 则是在从容器里第一次进行context.getBean(“”)时进行触发.Spring 启动的时候会把所有be ...

  2. JS 取消iOS播放自动全屏:

    iOS下浏览器模式下h5播放器强制是全屏的,除非在app下才可以非全屏播放,需要两个配置: (1)播放器添加参数: playsinline:true(我使用的是阿里云的播放器,其他的需要自己找找是那个 ...

  3. Spring框架(1)---Spring入门

    Spring入门 为了能更好的理解先讲一些有的没的的东西: 什么是Spring Spring是分层的JavaSE/EE full-stack(一站式) 轻量级开源框架 分层 SUN提供的EE的三层结构 ...

  4. Mysql 调优和水平扩展思路

    系统调优参数 一些比较重要的参数: back_log:back_log值指出在MySQL暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中.如果MySql的连接数据达到max_connecti ...

  5. SpringCloud入门之YAML格式文件规范学习

    1. 认识 YAML YAML(发音 /ˈjæməl/)是一个类似 XML.JSON 的数据序列化语言.其强调以数据为中心,旨在方便人类使用:并且适用于日常常见任务的现代编程语言.因而 YAML 本身 ...

  6. jpa的查询语法

  7. python模块之shutil

    shutil是一个用于简化文件操作的模块. 复制文件(传入源文件对象和目标文件对象) import shutil f1 = open(r'/Users/jingxing/PycharmProjects ...

  8. C#序列化与反序列化。

    序列化介绍: 把对象用一种新的格式来表示. 系列化只序列化数据. 序列化不建议使用自动属性 为什么要序列化: 将一个复杂的对象转换流,方便存储与信息交换. class Program { static ...

  9. C#比较两个对象是否为同一个对象。

    两个对象是否为同一个对象:是看两个对象是否指向堆中的同一块内存. 1.使用object.ReferenceEquals() class Program { static void Main(strin ...

  10. 【转载】ASP.NET实现文件下载的功能

    文件下载是很多网站中含有的常用功能,在ASP.NET中可以使用FileStream类.HttpRequest对象.HttpResponse对象相互结合,实现输出硬盘文件的功能.该方法支持大文件.续传. ...