Paramiko SSH 客户端无法解压 ED25519 密钥

Yu *_*hen 6 ssh paramiko python-3.x ed25519

我正在尝试使用密钥对与 SFTP 服务器进行 SSH 连接。

如果我通过 生成 RSA 密钥,我就可以这样做ssh-keygen -t rsa

当我通过 Paramiko 连接到服务器时,一切正常:

    private_key = paramiko.RSAKey.from_private_key_file("/path/to/my/private/key")
    client = paramiko.SSHClient()
    client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    print("Connecting.")
    client.connect(hostname="host.sftp.com", username="user", pkey=private_key)
    print("Connected.")
Run Code Online (Sandbox Code Playgroud)

但是,如果我尝试使用 ED25519 密钥执行此操作,则会收到以下错误:

ssh-keygen -t ed25519
Run Code Online (Sandbox Code Playgroud)
  File "/usr/local/lib/python3.7/site-packages/paramiko/pkey.py", line 235, in from_private_key_file
    key = cls(filename=filename, password=password)
  File "/usr/local/lib/python3.7/site-packages/paramiko/rsakey.py", line 55, in __init__
    self._from_private_key_file(filename, password)
  File "/usr/local/lib/python3.7/site-packages/paramiko/rsakey.py", line 176, in _from_private_key_file
    self._decode_key(data)
  File "/usr/local/lib/python3.7/site-packages/paramiko/rsakey.py", line 192, in _decode_key
    n, e, d, iqmp, q, p = self._uint32_cstruct_unpack(data, "iiiiii")
  File "/usr/local/lib/python3.7/site-packages/paramiko/pkey.py", line 529, in _uint32_cstruct_unpack
    raise SSHException(str(e))
paramiko.ssh_exception.SSHException: unpack requires a buffer of 4 bytes
Run Code Online (Sandbox Code Playgroud)

我在这里有点不知所措,因为谷歌搜索似乎没有产生任何相关的解决方案。这是内部的错误吗paramiko?这是我如何初始化我的问题SSHClient?或者这实际上是一个理论问题(即 ED25519 创建密钥的方式,不可能通过低级unpack()调用读入)?

Yu *_*hen 10

这是戴夫·汤普森的评论,作为结束这个循环的答案:

paramiko.RSAKey.from_private_key_file读取 RSA 密钥。要读取 Ed25519 密钥,请使用paramiko.Ed25519Key.from_private_key_file。(至少是 2.2.0。)

  • 似乎不起作用,“paramiko==2.7.1”:说“AttributeError:模块'paramiko.ed25519key'没有属性'from_private_key_file'”。也许又被删除了? (2认同)