Python之SSH-paramiko模块的使用

海棠未雨,梨花先雪,一半春休 / 2023-08-29 / 原文

一、paramiko介绍

1、 用于帮助开发者通过代码远程连接服务器,并对服务器进行操作。

pip3 install paramiko

二、通过用户名密码方式远程执行命令

1、用户名密码

import paramiko

# 创建SSH对象
ssh = paramiko.SSHClient()

# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

# 连接服务器
ssh.connect(hostname='192.168.200.132', port=22, username='root', password='5740##')

# 执行命令
stdin, stdout, stderr = ssh.exec_command('df -Th')

# 获取命令结果
result = stdout.read()

# 关闭连接
ssh.close()

print(result.decode('utf-8'))

三、通过用户名密码方式上传下载文件

1、传文件

import paramiko

transport = paramiko.Transport(('192.168.200.132', 22))

transport.connect(username='root', password='5740##')

sftp = paramiko.SFTPClient.from_transport(transport)


# sftp.put('123.txt', '/data/123.txt')
sftp.get('/data/123.txt', '/root/123.txt')

transport.close()

四、通过公钥私钥远程执行命令

1、代码

import paramiko

private_key = paramiko.RSAKey.from_private_key_file('/root/.ssh/id_rsa')

# 创建SSH对象
ssh = paramiko.SSHClient()

# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

# 连接服务器
ssh.connect(hostname='192.168.200.132', port=22, username='root', pkey=private_key)

# 执行命令
stdin, stdout, stderr = ssh.exec_command('df -Th')

# 获取命令结果
result = stdout.read()

# 关闭连接
ssh.close()

print(result)  

注:

在 Paramiko 中,pkey 选项用于指定用于身份验证的私钥。具体来说,这个选项允许你提供一个 paramiko.RSAKeyparamiko.DSSKey 对象,这些对象表示了你的私钥文件

如果你使用 RSA 密钥作为私钥,你可以按照以下方式设置 pkey 选项:

private_key = paramiko.RSAKey.from_private_key_file('/path/to/private/key')

如果你使用 DSA 密钥,可以这样设置:

private_key = paramiko.DSSKey.from_private_key_file('/path/to/private/key')

在连接服务器时,你可以将 private_key 对象传递给 pkey 参数,

五、通过公钥私钥远程上传下载文件

1、sftp.put

import paramiko

private_key = paramiko.RSAKey.from_private_key_file(r'/root/.ssh/id_rsa')

transport = paramiko.Transport(('192.168.200.132', 22))

transport.connect(username='root', pkey=private_key)

sftp = paramiko.SFTPClient.from_transport(transport)

# 将location.py 上传至服务器 /tmp/test.py
sftp.put('/data/123.py', '/root/123.py')

# 将remove_path 下载到本地 local_path
# sftp.get('123.py', '123.py')

transport.close()

六、通过私钥字符串远程连接服务器

# 也可以是存在于数据库中
key = """-----BEGIN RSA PRIVATE KEY-----

-----END RSA PRIVATE KEY-----"""


import paramiko
from io import StringIO

private_key = paramiko.RSAKey(file_obj=StringIO(key))

# 创建SSH对象
ssh = paramiko.SSHClient()
# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 连接服务器
ssh.connect(hostname='192.168.16.85', port=22, username='root', pkey=private_key)

# 执行命令
stdin, stdout, stderr = ssh.exec_command('df')
# 获取命令结果
result = stdout.read()

# 关闭连接
ssh.close()

print(result)