Python 基于Python实现的ssh兼sftp客户端(上)
基于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客户端(上)的更多相关文章
- Python 基于Python实现的ssh兼sftp客户端(下)
基于Python实现的ssh兼sftp客户端 by:授客 QQ:1033553122 otherTools.py #!/usr/bin/env/ python # -*- coding:utf-8 ...
- Python 基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现
基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现 by:授客 QQ:1033553122 测试环境 功能需求 实现思路 代码实践(关键技术点实现) 代码模块组织 ...
- Python 基于python操纵zookeeper介绍
基于python操纵zookeeper介绍 by:授客 QQ:1033553122 测试环境 Win7 64位 Python 3.3.4 kazoo-2.6.1-py2.py3-none-any.w ...
- Python 基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控
基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控 By: 授客 QQ:1033553122 1.测试环境 python 3.4 zookeeper- ...
- Python 基于Python从mysql表读取千万数据实践
基于Python 从mysql表读取千万数据实践 by:授客 QQ:1033553122 场景: 有以下两个表,两者都有一个表字段,名为waybill_no,我们需要从tl_waybill_b ...
- Python基于Python实现批量上传文件或目录到不同的Linux服务器
基于Python实现批量上传文件或目录到不同的Linux服务器 by:授客 QQ:1033553122 实现功能 1 测试环境 1 使用方法 1 1. 编辑配置文件conf/rootpath_fo ...
- Python 基于python编写一些算法程序等
基于python编写一些算法程序等 by:授客 QQ:1033553122 QQ群:7156436 没特意去研究,只是这对群友在QQ群里(7156436)提出的一些小程序实现.编程题,算法.问题等,本 ...
- Python 基于python+mysql浅谈redis缓存设计与数据库关联数据处理
基于python+mysql浅谈redis缓存设计与数据库关联数据处理 by:授客 QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3 ...
- Python 基于python操纵redis入门介绍
基于python操纵redis入门介绍 by:授客 QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3.3.2 基于Python操作R ...
随机推荐
- linux下 几个常用makefile模板,亲测可用
一 生成动态链接库的模板: ####################### # Makefile ####################### # compile and lib parameter ...
- murri
github: https://github.com/haltu/muuri 官网:https://haltu.github.io/muuri/ 安装 npm install murri —sav ...
- 浅谈JavaScript 函数作用域当中的“提升”现象
在JavaScript当中,定义变量通过var操作符+变量名.但是不加 var 操作符,直接赋值也是可以的. 例如 : message = "hello JavaScript ! " ...
- shiro 返回json字符串 + 自定义filter
前言: 在前后端分离的项目中, 在使用shiro的时候, 我们绝大部分时候, 并不想让浏览器跳转到那个页面去, 而是告诉前端, 你没有登录, 或者没有访问权限. 那这时候, 我们就需要返回json字符 ...
- nginx proxy_pass 代理域名
一.描述 1.nginx配置转发的时候使用的是域名,即使用dns服务方便配置和负载.但是nginx默认会进行缓存,当域名对应的服务出问题的时候就会报错,只有默认的缓存时间到了才会再次进行解析,ngin ...
- go等待N个线程完成操作总结
第一种,基于原生带缓存的channel package main import "fmt" func main() { done := make(chan int, 10) for ...
- 教你用Python创建瀑布图
介绍 对于绘制某些类型的数据来说,瀑布图是一种十分有用的工具.不足为奇的是,我们可以使用Pandas和matplotlib创建一个可重复的瀑布图. 在往下进行之前,我想先告诉大家我指代的是哪种类型的图 ...
- Python转页爬取某铝业网站上的数据
天行健,君子以自强不息:地势坤,君子以厚德载物! 好了废话不多说,正式进入主题,前段时间应朋友的请求,爬取了某铝业网站上的数据.刚开始呢,还是挺不愿意的(主要是自己没有完整的爬取过网上的数据哎,即是不 ...
- 【Go】IP地址转换:数字与字符串之间高效转换
转载:https://blog.thinkeridea.com/201903/go/ip2long.html IP 地址库中 IP 地址的保存格式一般有两种,一种是点分十进制形式(192.168.1. ...
- python装饰器2:类装饰器
装饰器1:函数装饰器 装饰器2:类装饰器 装饰器3:进阶 本文是装饰器相关内容的第二篇,关于类装饰器. "类装饰器"有两种解读方式:用来装饰类的装饰器:类作为装饰器装饰其它东西.你 ...

