php中文网

如何将 SSH 公钥和私钥转换为 Java 中的 RSAPublicKey 和 RSAPrivateKey?

php中文网

SSH 公钥和私钥在 Java 中转换为 RSAPublicKey 和 RSAPrivateKey

使用 ssh-keygen 生成的公钥和私钥如何转换到 Java 中的 RSAPublicKey 和 RSAPrivateKey 对象?

问题分析

您遇到的问题是,使用由 ssh-keygen 生成的公钥字符串调用 string2PublicKey 函数时出现错误。原因在于 ssh-keygen 生成的公钥和 X.509 标准中定义的 PEM 格式不同。

立即学习“Java免费学习笔记(深入)”;

解决方法

要将 ssh-keygen 生成的公钥转换为 RSAPublicKey,需要对其进行特殊的处理:

  1. 解码公钥:使用 Base64 解码密钥字符串。
  2. 取消 SSH 头:忽略前 11 个字节("0007ssh-rsa")。
  3. 读取指数长度:将第 11 到第 14 个字节转换为数字,表示指数的字节长度。
  4. 读取指数:获取第 15 到第 (14 + 指数长度) 个字节并转换为大端十进制。
  5. 读取模数长度:将第 (15 + 指数长度) 到第 (19 + 指数长度) 个字节转换为数字,表示模数的字节长度。
  6. 读取模数:获取第 (20 + 指数长度) 到第 (20 + 指数长度 + 模数长度) 个字节并转换为大端十进制。
  7. 生成 RSAPublicKeySpec:使用读取到的指数和大整数创建 RSAPublicKeySpec 对象。
  8. 生成 RSAPublicKey:使用 KeyFactory.generatePublic 方法从 RSAPublicKeySpec 生成 RSAPublicKey 对象。

经过这些步骤,您就可以将 ssh-keygen 生成的公钥转换成 Java 中的 RSAPublicKey。

请注意,类似的步骤也适用于将 ssh-keygen 生成的私钥转换为 RSAPrivateKey。

以上就是如何将 SSH 公钥和私钥转换为 Java 中的 RSAPublicKey 和 RSAPrivateKey?的详细内容,更多请关注php中文网其它相关文章!