Paramiko是一个Python实现的SSH2远程安全连接模块,它支持认证及密钥方式。

Paramiko是一个Python实现的SSH2远程安全连接模块,它支持认证及密钥方式。

具体来说,Paramiko是一个用于实现SSHv2协议的模块,它可以用于创建SSH客户端或服务器端。通过使用Paramiko,你可以连接到远程服务器、执行命令、传输文件等操作。Paramiko还支持多种认证方式,包括口令认证和公钥认证,以及多种密钥交换算法和压缩方法。

使用Paramiko模块可以编写Python代码,实现SSH相关功能,例如文件传输、远程执行命令等。

安装方式

python 复制代码
sudo apt-get install build-essential libssl-dev libffi-dev python3-dev 
pip3 install cryptography
pip3 install paramiko

示例:

python 复制代码
import paramiko

ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())  # 自动添加主机密钥
ssh.connect('remote_host', username='your_username', password='your_password')
#hostname:连接的目标主机。
#port=SSH_PORT:指定端口,一般默认为22。
#username=None:验证的用户名。
#password=None:验证的用户密码。
#pkey=None:私钥方式用于身份验证。
#key_filename=None:一个文件名或文件列表,指定私钥文件。
#timeout=None:可选的tcp连接超时时间。
#allow_agent=True:是否允许连接到ssh代理,默认为True。
#look_for_keys=True:是否在~/.ssh中搜索私钥文件,默认为True。
#compress=False:是否打开压缩。
#常用方法:
#connect():主要是用于实现和远程服务器的连接与认证。

stdin, stdout, stderr = ssh.exec_command('ls')
output = stdout.read().decode()
print(output)

sftp = ssh.open_sftp()
sftp.put('local_file', 'remote_file')  # 上传文件
sftp.close()

终端示例

python 复制代码
>>> import paramiko, time
>>> connection = paramiko.SSHClient()
>>> connection.set_missing_host_key_policy(paramiko.AutoAddPolicy())
>>> connection.connect('192.168.2.51', username='cisco', password='cisco', 
look_for_keys=False, allow_agent=False)
>>> new_connection = connection.invoke_shell()
>>> output = new_connection.recv(5000)
>>> print(output) b"\
r\n*************************************************************************\
r\n* IOSv is strictly limited to use for evaluation, demonstration and 
IOS *\r\n* education. IOSv is provided as-is and is not supported by 
Cisco's *\r\n* Technical Advisory Center. Any use or disclosure, 
in whole or in part, *\r\n* of the IOSv Software or Documentation to 
any third party for any *\r\n* purposes is expressly prohibited 
except as otherwise authorized by *\r\n* Cisco in writing. 
*\r\n*********************************************************************
**\r\nlax-edg-r1#"
>>> new_connection.send("show version | i V\n")
19
>>> time.sleep(3)
>>> output = new_connection.recv(5000)
>>> print(output)
b'show version | i V\r\nCisco IOS Software, IOSv Software (VIOSADVENTERPRISEK9-M), Version 15.8(3)M2, RELEASE SOFTWARE (fc2)\r\nProcessor 
board ID 98U40DKV403INHIULHYHB\r\nlax-edg-r1#'
>>> new_connection.close()
>>>
python 复制代码
>>> import paramiko
>>> connection = paramiko.SSHClient()
>>> connection.set_missing_host_key_policy(paramiko.AutoAddPolicy())
>>> connection.connect('192.168.2.51', username='cisco', password='cisco',
look_for_keys=False, allow_agent=False)
>>> stdin, stdout, stderr = connection.exec_command('show version | i 
V\n') 
Traceback (most recent call last):
<skip>
raise SSHException('SSH session not active') paramiko.ssh_exception.
SSHException: SSH session not active
python 复制代码
ssh-keygen -t rsa
cat ~/.ssh/id_rsa.pub
>>> import paramiko
>>> key = paramiko.RSAKey.from_private_key_file('/home/xxx/.ssh/id_rsa')
>>> client = paramiko.SSHClient()
>>> client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
>>> client.connect('192.168.199.182', username='echou', pkey=key)
>>> stdin, stdout, stderr = client.exec_command('ls -l')
>>> stdout.read()
b'total 44ndrwxr-xr-x 2 echou echou 4096 Jan 7 10:14 Desktopndrwxr-xr-x 2
echou echou 4096 Jan 7 10:14 Documentsndrwxr-xr-x 2 echou echou 4096 Jan 7
10:14 Downloadsn-rw-r--r-- 1 echou echou 8980 Jan 7 10:03
examples.desktopndrwxr-xr-x 2 echou echou 4096 Jan 7 10:14 Musicndrwxrxr-x
echou echou 4096 Jan 7 10:14 Picturesndrwxr-xr-x 2 echou echou 4096 Jan 7 
10:14 Publicndrwxr-xr-x 2 echou echou 4096 Jan 7 10:14 Templatesndrwxrxr-x
2 echou echou 4096 Jan 7 10:14 Videosn'
>>> stdin, stdout, stderr = client.exec_command('pwd')
>>> stdout.read()
b'/home/echou'
>>> client.close()
相关推荐
眸笑丶1 分钟前
使用 Python 调用 Ollama API 并调用 deepseek-r1:8b 模型
开发语言·python
dexianshen4 分钟前
配置mysql8.0使用PXC实现高可用
python
中国loong6 分钟前
pandas连接mysql数据库
python
带娃的IT创业者34 分钟前
《Python实战进阶》专栏 No.3:Django 项目结构解析与入门DEMO
数据库·python·django
HealthScience1 小时前
【异常错误】pycharm debug view变量的时候显示不全,中间会以...显示
ide·python·pycharm
豌豆花下猫2 小时前
Python 潮流周刊#90:uv 一周岁了,优缺点分析(摘要)
后端·python·ai
橘猫云计算机设计2 小时前
基于SSM的《计算机网络》题库管理系统(源码+lw+部署文档+讲解),源码可白嫖!
java·数据库·spring boot·后端·python·计算机网络·毕设
小伍_Five2 小时前
从0开始:OpenCV入门教程【图像处理基础】
图像处理·python·opencv
m0_748245343 小时前
python——Django 框架
开发语言·python·django
java1234_小锋3 小时前
一周学会Flask3 Python Web开发-客户端状态信息Cookie以及加密
前端·python·flask·flask3