基于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. 【Hadoop】2、Hadoop高可用集群部署

    1.服务器设置 集群规划 Namenode-Hadoop管理节点 10.25.24.92 10.25.24.93 Datanode-Hadoop数据存储节点 10.25.24.89 10.25.24. ...

  2. 利用vi编辑器创建和编辑正文文件(二)

    末行模式下的命令 1.       w:写文件,将编辑的内容保存到文件系统. 2.       w!:如果只读文件,强制写入系统. 3.       q!:退出vi,但文件内容修改的话,系统要提示是否 ...

  3. GODOT 3.0 开发进度汇报 #7

    由于原文采取了记流水账的方式,觉得没有必要照直翻译了,就只选取了其中的主要信息. GDNative C++ 语言绑定 进行了重写以便Godot更好的生成和处理脚本. D 语言绑定 也正在积极开发中. ...

  4. 图片base64上传时可能遇到的问题

    base64上传图片时服务器接到的值可能会丢失字符串 解决方法如下:(分为单个上传和多个上传) <?php $BASE_DIR = "../"; //文件上传 $img = ...

  5. Python爬虫、自动化常用库&帮助文档URL

    一.Python下载地址 Windows终端Cmder.exe下载--->http://cmder.net/ Python下载(Windows)        ---> https://w ...

  6. Apache Flume 1.7.0 自定义输入输出

    自定义http source config a1.sources.r1.type=http a1.sources.r1.bind=localhost a1.sources.r1.port= a1.so ...

  7. 对小程序框架WePY的精简总结

    一.注意点 关闭ES6转ES5关闭上传代码时样式自动补全关闭代码压缩上传本地开发选择dist目录,dist目录也用在开发者工具上实时预览和调试WePY框架对应的开发目录为src二.代码规范 - 变量方 ...

  8. MySQL 锁信息和事务

    1 锁概念 1.1 什么是锁 锁是数据库系统区别于文件系统的一个关键特性.数据库系统使用锁是为了支持对共享资源进行并发访问,提供数据的完整性和一致性.例如:操作缓冲池中的LRU列表,删除.添加.移动L ...

  9. 【原创】VirtualBox 磁盘扩容教程

    问题和环境说明 环境: 主机:Ubuntu 15.10 客户机:Windows 7 x64 VirtualBox:5.0.10 虚拟机磁盘类型:VDI(VirtualBox磁盘映像) 问题: 在虚拟机 ...

  10. Ubuntu 下 Galera cluster for MySQL 集群安装

    mysql galera cluster官网:http://galeracluster.com/documentation-webpages/ 相关安装教程:(不一定管用) http://blog.c ...