AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / computer / 问题 / 1470852
Accepted
Vicfred
Vicfred
Asked: 2019-08-14 04:34:12 +0800 CST2019-08-14 04:34:12 +0800 CST 2019-08-14 04:34:12 +0800 CST

ssh-keygen 私钥和 libressl 的区别?

  • 772

我使用 libressl 3.0 使用 curve 生成​​了私钥secp521r1。

openssl genpkey -aes128 -algorithm EC -pkeyopt ec_paramgen_curve:secp521r1 -pkeyopt ec_param_enc:named_curve

据我所知,这条曲线与 ssh-keygen 使用的曲线相同,ssh-keygen -t ecdsa -b 521我知道 ssh-keygen 现在使用 aes128 来加密私钥。

libressl 私钥534的大小为 ,ssh-keygen 的大小为736。

我的问题是:ssh-keygen 会增加密钥的大小吗?

另外:两者都可以交换吗?一个生成的私钥可以转换为另一个吗?

openssl public-key
  • 1 1 个回答
  • 945 Views

1 个回答

  • Voted
  1. Best Answer
    dave_thompson_085
    2019-08-15T06:54:53+08:002019-08-15T06:54:53+08:00

    TLDR:私钥文件有很多不同的格式

    它部分取决于您没有提供的 OpenSSH 版本。

    从历史上看,除了长期过时的协议版本 1(和密钥类型“rsa1”)外,OpenSSH 使用 OpenSSL(的 libcrypto 部分)来完成其大部分加密操作——包括在文件中存储私钥(或有效的密钥对),使用SSLeay/OpenSSL 定义的“传统”或“遗留”格式。OpenSSL 还支持“新”(大约从 1998 年开始!)PKCS8 格式,这些格式(有点)更安全。因此,OpenSSL 支持 4 种用于“ECDSA”的 PEM 格式(更确切地说,X9 风格的 Weierstrass EC 涵盖了 X9.62 ECDSA 和 X9.63 ECDH),其中 OpenSSH仅生成2 种,但(使用 libcrypto)可以读取所有格式。在ssh-keygen加密OpenSSL 格式的文件时,最新版本确实使用 AES-128-CBC,但这并非总是如此。

    从 2014-01 的 6.5 版开始,OpenSSH 添加了自己的“新”文件格式,部分是为了提供比 OpenSSL 传统格式(加密时)更好的安全性,部分是为了支持当时的新算法 Ed25519,OpenSSL 当时不支持该算法根本。ssh-keygen有一个选项-o可以为 ed25519(或 rsa1)以外的任何密钥类型请求新格式,您会发现过去几年的许多 Stack Q 和 As 都引用并通常推荐这个选项。默认情况下,“新”格式文件使用 AES256-CBC 加密,可以使用 覆盖-Z ciphername,但手册页显然没有针对其中任何一个进行更新。从 2018-08 版 7.8 开始,OpenSSH 现在默认为所有密钥类型使用“新”格式,尽管您可以使用-m pem为 ed25519 以外的任何内容请求 OpenSSL 格式。如果您检查man ssh-keygen您的系统(除非是 Windows),它应该描述其中一种情况,可能是后者。

    (还有 PKCS12 aka PFX 格式,OpenSSL可以将其用于私钥,但通常仅用于将一个(或多个)私钥与该(那些)密钥的一个或多个 X.509 证书组合起来,这是一种不同的情况,不适用于从不使用 X.509 证书的 SSH。其他程序或系统使用其他格式:'commercial'/Tectia SSH 有自己的格式,PuTTY 有自己的格式 PPK = PuTTY Private Key .等等,等等,Yul Brynner。所有这些在语义上都是等价的,并且可以通过合适的工具相互转换。)

    OpenSSH 使用的所有私钥格式都是PEM 样式;二进制数据被编码为 base64 格式的文本,标题和结尾行的格式为

    -----BEGIN (something)-----
    (sometimes some headers here)
    (data encoded in base64, broken into lines of 64 characters)
    -----END (something)-----
    

    所以你可以通过查看破折号 - 开始行来判断你使用的是哪种格式。请参阅近交叉复制https://security.stackexchange.com/questions/39279/stronger-encryption-for-ssh-keys或更简短的https://security.stackexchange.com/questions/129724/how-to-check- if-an-ssh-private-key-has-passphrase-or-not和https://security.stackexchange.com/questions/200935/how-do-i-determine-if-an-existing-ssh-private-密钥是安全的(我的)。

    区别: ecdsa-p521 密钥的 736 个字符的大小与未加密的 OpenSSH 新格式相匹配——你确定你给了它一个密码吗?-- 并且 534 匹配由 OpenSSL 1.0.2 创建的 PKCS8 加密格式,IIRC 在 LibreSSL 分叉时使用。(OpenSSL 1.1.0 up 更改了 PKCS8 加密以在 PBKDF2 中使用 HMAC-SHA256,这使得文件略大。OpenSSL 1.1.0 up 还使 param_enc=named 成为默认值,因此您不再需要指定它。)OpenSSH new格式比 PKCS8-enc 格式大主要是因为,没有明显的原因,它存储公钥值(对于 ECDSA,X9.62 格式的曲线点)两次——一次在为公钥指定的文件部分,然后再次在为私钥指定的部分中。此外,OpenSSH 格式的大部分元数据都是文本字符串,所有长度字段都是 4 字节,而 PKCS8(与 OpenSSL 传统格式一样)使用 ASN.1,可变长度字段大多只有 1 字节,元数据大多是二进制,尤其是所用算法的“OID”。)

    另外:两者都可以交换吗?一个生成的私钥可以转换为另一个吗?

    是和不是。如前所述,使用 OpenSSL 的 OpenSSH 可以读取(但不能写入)PKCS8,因此ssh-keygen可以通过对其进行空更改将其转换为 OpenSSH-new,即将密码“更改”为现有值;从 6.5 到 7.7,您必须指定-o,从 7.8 开始,它是默认值。换句话说,ssh-keygen可以转换为 OpenSSL-legacy,但不能直接转换为 PKCS8,你需要使用它openssl来做到这一点,无论是明确地使用pkcs8 -topk8还是在 1.0.0 up(现在应该是每个人,而且肯定是所有 LibreSSL)只是pkey。(前者默认为加密,后者默认为未加密,但两者都可以被覆盖。)

    • 4

相关问题

  • 如何解决:警告:使用过时的密钥推导。使用 -iter 或 -pbkdf2 会更好

  • OpenSSL 支持 ed25519,加密内容?

  • 如何验证 SSL 证书文件是否与密钥文件匹配?

  • 使用 openssl 生成 JWT RS256 签名

  • 加载密钥“ec256.pem”:尝试从私钥生成公钥时抛出无效格式

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    Windows 10 服务称为 AarSvc_70f961。它是什么,我该如何禁用它?

    • 2 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Marko Smith

    ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] 证书验证失败:无法获取本地颁发者证书 (_ssl.c:1056)

    • 4 个回答
  • Marko Smith

    我如何知道 Windows 安装在哪个驱动器上?

    • 6 个回答
  • Martin Hope
    Albin 支持结束后如何激活 WindowsXP? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 “HTTPS Everywhere”仍然相关吗? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch Windows 10 删除大量小文件的速度非常慢。有什么办法可以加快速度吗? 2019-09-23 06:05:43 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    Inter Sys Ctrl+C 和 Ctrl+V 是如何工作的? 2019-05-15 02:51:21 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve