poo*_*gar 6 python ssh sftp pysftp private-key
我想传递我的实际私钥值作为参数,而不是提供文件路径。
到目前为止我已经使用了以下代码:
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)
Run Code Online (Sandbox Code Playgroud)
请建议某种方式将其作为文本传递。
例子:
private_key='abcdmyprivatekeytext'
Run Code Online (Sandbox Code Playgroud)
在实际场景中,我会将我的私钥文本放置在安全保管库中。
pysftp 可以RSAKey在构造函数private_key的参数中接受:Connection
# 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)
Run Code Online (Sandbox Code Playgroud)
(最初由@Hana发布,但答案现已删除)
从 pysftp 0.2.9 开始,这种参数的使用private_key不受文档支持,但它是有效的。不接受其他密钥类型(DSSKey、ECDSAKey、 )。Ed25519Key
如果您需要使用其他密钥类型,请直接使用 Paramiko:
SSH/SCP 通过 Paramiko,密钥为字符串
pysftp 只是 Paramiko 周围废弃的包装。
更喜欢直接使用 Paramiko:pysftp 与 Paramiko