Python PYSFTP-以字符串/文本形式传递私钥,而不是传递文件路径
问题描述
我希望将我的实际私钥值作为参数传递,而不是提供文件路径。
到目前为止,我已经使用了以下代码:
import pysftp
import os
cnopts = pysftp.CnOpts()
if str(host_keys).lower() =='none':
cnopts.hostkeys = None
else:
cnopts.hostkeys.load(hostkeys)
filename = os.path.basename(localpath)
print(filename)
remotepath = os.path.join(remotefolder, filename)
print(remotepath)
with pysftp.Connection(host=hostname, port=int(port), username=username, password=password, cnopts=cnopts,private_key=private_key_filepath) as sftp:
sftp.put(localpath, remotepath=remotepath)
请建议将其作为文本传递的方法。
示例:
private_key='abcdmyprivatekeytext'
在实际方案中,我将把我的私钥文本放在安全保险库中。
解决方案
可以接受RSAKey
参数RSAKey
中的RSAKey
:
# Set your private key as a string
PRIVATE_KEY = """-----BEGIN RSA PRIVATE KEY-----
...
-----END RSA PRIVATE KEY-----
"""
# Use 'io.StringIO' to read your string as a file-like object.
privkey = io.StringIO(PRIVATE_KEY)
# Use paramiko to create your RSAKey
ki = paramiko.RSAKey.from_private_key(privkey)
# Connect using your key with pysftp
conn = pysftp.Connection(host=HOST, username=USER, private_key=ki)
(最初由@hana发布,但现在已删除答案)
这种private_key
参数的用法不受来自pysftp 0.2.9的文档的支持,但它是有效的。不接受其他密钥类型(DSSKey
、ECDSAKey
、Ed25519Key
)。
如果您需要使用其他密钥类型,请直接使用Paramiko:
SSH/SCP through Paramiko with key in string
pysftp只是Paramiko的废弃包装器。
更喜欢直接使用Paramiko:pysftp vs. Paramiko
相关文章