Paramiko:不是有效的DSA私钥文件

2022-09-01 00:00:00 python sftp pysftp paramiko

问题描述

我正在尝试使用如下所示的私钥文件连接到某些SFTP:

---- BEGIN SSH2 ENCRYPTED PRIVATE KEY ----
Subject: L0709146
Comment: "1024-bit dsa, L0709146@pxz102, Wed Jan 12 2022 11:25:54 +010
0"
P2/bla...bla...bla
---- END SSH2 ENCRYPTED PRIVATE KEY ----

使用以下代码:

import paramiko
path = "path/to/my/file"

transport = paramiko.Transport((self.host, self.port))
transport.connect(username=self.user,pkey=paramiko.DSSKey.from_private_key(open(path)))
# ^^^ Error line ^^^

#transport.connect(username=self.user,pkey=paramiko.RSAKey.from_private_key(open(path)))
#transport.connect(username=self.user,pkey=paramiko.ECDSAKey.from_private_key(open(path)))
sftp = paramiko.SFTPClient.from_transport(transport)
logging.info(sftp.listdir())

我不确定,但我知道这是一个DSA私钥文件,但我获得了错误:

pariko.ssh_Exception.SSHException:不是有效的DSA私钥文件

我尝试了其他选项,但出现了类似的错误

paramiko.ssh_exception.SSHException: not a valid RSA private key file
paramiko.ssh_exception.SSHException: not a valid EC private key file
paramiko.ssh_exception.SSHException: not a valid OPENSSH private key file

我使用了FileZilla客户端,连接到SFTP没有问题,我不明白为什么使用Python会有问题。

ssh.com

您有一个很少使用的推荐答案格式的私钥。帕拉米科不支持它。您必须将其转换为OpenSSH格式。

您可以这样使用ssh-keygen

ssh-keygen -i -f sshcomkey > opensshkey

在Windows上,您还可以使用PuTTYgen。

相关问题:Paramiko: "not a valid RSA private key file"

相关文章