【问题标题】:Paramiko: "not a valid DSA private key file"Paramiko:“不是有效的 DSA 私钥文件”
【发布时间】:2022-01-24 15:27:35
【问题描述】:

我正在尝试使用如下所示的私钥文件连接到某些 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 私钥文件,但我得到了错误:

paramiko.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 会出现问题。

【问题讨论】:

    标签: python sftp paramiko pysftp


    【解决方案1】:

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

    你可以像这样使用ssh-keygen

    ssh-keygen -i -f sshcomkey > opensshkey
    

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

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

    【讨论】:

      猜你喜欢
      • 2019-07-03
      • 2018-01-31
      • 2018-09-05
      • 1970-01-01
      • 2019-05-05
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多