【问题标题】:Bouncycastle can't generate private key - Unknown KeySpec type: java.security.spec.X509EncodedKeySpecBouncycastle 无法生成私钥 - 未知 KeySpec 类型:java.security.spec.X509EncodedKeySpec
【发布时间】:2019-06-24 16:35:46
【问题描述】:

由于未知的 KeySpec 类型:java.security.spec.X509EncodedKeySpec,我无法使用 bouncycastle 生成私钥。 (但是,对公钥执行相同操作不会引发异常并且有效 - 为什么?)

java.security.spec.InvalidKeySpecException:未知的 KeySpec 类型: java.security.spec.X509EncodedKeySpec 在 org.bouncycastle.jcajce.provider.asymmetric.rsa.KeyFactorySpi.engineGeneratePrivate(未知 来源)在 java.security.KeyFactory.generatePrivate(KeyFactory.java:366)

        PemReader pemReader = new PemReader(new InputStreamReader(new FileInputStream("private_unencrypted.pem")));
        PemObject pemObject = pemReader.readPemObject();
        pemReader.close();

        KeyFactory keyFactory = KeyFactory.getInstance("RSA", "BC");
        byte[] privateKeyBytes = pemObject.getContent();
        X509EncodedKeySpec x509KeySpec = new X509EncodedKeySpec(privateKeyBytes);
        PrivateKey privateKey = keyFactory.generatePrivate(x509KeySpec);

【问题讨论】:

  • 发布您的密钥文件内容。
  • 此外,我假设您应该使用 PKCS8EncodedKeySpec 作为 rsa 私钥,除非它是 PKCS1 编码的。
  • @michalk 是的,使用 PKCS8EncodedKeySpec 代替了它。谢谢!

标签: java bouncycastle


【解决方案1】:

对于 RSA 私钥,如果您的密钥以 PKCS8 格式编码,您应该使用 PKCS8EncodedKeySpec。 PKCS8 格式通常看起来像:

-----BEGIN PRIVATE KEY-----
base64 encoded der key
-----END PRIVATE KEY-----

如果您的密钥是 PKCS1 格式并且看起来像:

-----BEGIN RSA RIVATE KEY-----
base64 der encoded key
-----END RSA PRIVATE KEY-----

你应该先将其转换为PKCS8格式,然后使用上面提到的类。

但是,对公钥执行相同操作不会引发异常并且有效 - 为什么?

因为公钥通常是证书的一部分,以 X509 格式编码,而私钥通常以 PKCS 格式编码。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-10-01
    • 1970-01-01
    • 1970-01-01
    • 2015-06-18
    • 2016-07-03
    • 1970-01-01
    相关资源
    最近更新 更多