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 ...
随机推荐
- 你不知道的JavaScript --- 作用域相关
本篇是<你不知道的JavaScript>的读书笔记 什么是作用域? 程序离不变量,那么变量存储在哪里?程序需要时如何找到他们? 这些问题说明需要一套设计良好的规则来存储变量, 并且之后可以 ...
- 必须要会的 50 个 React 面试题
翻译:疯狂的技术宅 原文:www.edureka.co/blog/interv… 如果你是一位有抱负的前端程序员并准备面试,那么这篇文章很适合你.本文是你学习和面试 React 所需知识的完美指南. ...
- 剑指offer【07】- 斐波那契数列(java)
题目:斐波那契数列 考点:递归和循环 题目描述:大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0),n<=39. 法一:递归法,不过递归比较慢, ...
- Intellij IDEA神器居然还有这些小技巧
概述 Intellij IDEA真是越用越觉得它强大,它总是在我们写代码的时候,不时给我们来个小惊喜.出于对Intellij IDEA的喜爱,我决定写一个与其相关的专栏或者系列,把一些好用的Intel ...
- Excel 斜线表头制作方法
Excel 斜线表头制作方法
- Struts标签<bean:write><logic:iterate></logic:equal>的组合使用小例
form表单中的一个下拉列表控件的代码如下 <select name="taskname" id="taskname" class="selec ...
- Kubernetes 持续集成 SpringCloud
写在开始之前,在开始之前我们需要了解几个概念: 1.什么是持续集成? 持续集成是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员每天至少集成一次,也就意味着每天可能会发生多次集成.每次 ...
- Salesforce Sales Cloud 零基础学习(四) Chatter
Chatter是一个Salesforce实时协作应用程序,它允许你的用户一起工作.互相交谈和共享信息,不管用户角色或位置如何,连接.并激励用户在整个组织内高效工作. Chatter 让用户们在 Opp ...
- 教你一个vue小技巧,一般人我不说的
本文由云+社区发表 1. 需求 最近的项目中,需要实现在vue框架中动态渲染带提示框的单选/多选文本框,具体的效果如下图所示,在输入框聚焦时,前端组件通过接收的kv参数渲染出选项,用户点击选项,可以将 ...
- 关于kubernetes使用私有仓库一点说明
一.概述 关于kubernetes使用私有docker image registry的一些说明: 1.对于自己构建的项目镜像或一些不想暴露到外网的image需要使用自建的私有仓库,一般有两种选择:d ...

