gpt4 book ai didi

java - 如何使用 SunMSCAPI key 解密 RSA-OAEP

转载 作者:行者123 更新时间:2023-11-30 07:39:47 25 4
gpt4 key购买 nike

我有一个带有私钥的证书存储在 Windows 证书库中。如何使用此 key 解密使用 OAEP 填充的消息?我可以使用 BouncycaSTLe 提供程序和 pfx 文件(PKCS12 keystore )解密消息,但不能使用 Windows 商店 (SunMSCAPI)。

我基本上使用这段代码

KeyStore keyStore = java.security.KeyStore.getInstance("Windows-MY");
keyStore.load(null, null);
PrivateKey privateKey = (PrivateKey) keyStore.getKey("keyalias", null);

java.security.Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());

JceKeyTransRecipient jceKeyTransEnvelopedRecipient = new JceKeyTransEnvelopedRecipient(privateKey);
CMSEnvelopedData envelopedData = new CMSEnvelopedData(Base64.getDecoder().decode(encryptedData));
RecipientInformationStore recipientInfos = envelopedData.getRecipientInfos();
RecipientInformation recipient = recipientInfos.getRecipients().iterator().next();
byte[] decrypted = recipient.getContent(jceKeyTransEnvelopedRecipient);

结果是

Caused by: java.security.InvalidKeyException: No installed provider supports this key: sun.security.mscapi.RSAPrivateKey
at javax.crypto.Cipher.chooseProvider(Cipher.java:892)
at javax.crypto.Cipher.init(Cipher.java:1248)
at javax.crypto.Cipher.init(Cipher.java:1185)
at org.bouncycastle.operator.jcajce.JceAsymmetricKeyUnwrapper.generateUnwrappedKey(JceAsymmetricKeyUnwrapper.java:148)

如果我这样指定提供者:

JceKeyTransRecipient jceKeyTransEnvelopedRecipient = new JceKeyTransEnvelopedRecipient(privateKey).setProvider("SunMSCAPI");

然后我得到错误(不支持 OAEP)

Caused by: java.security.NoSuchAlgorithmException: No such algorithm: 1.2.840.113549.1.1.7
at javax.crypto.Cipher.getInstance(Cipher.java:687)
at javax.crypto.Cipher.getInstance(Cipher.java:595)
at org.bouncycastle.jcajce.util.NamedJcaJceHelper.createCipher(NamedJcaJceHelper.java:47)
at org.bouncycastle.operator.jcajce.OperatorHelper.createAsymmetricWrapper(OperatorHelper.java:267)

不久,java 不支持 OAEP,即使 BC 支持 OAEP,它也不能将其用于“外部” key 。如果是这样,还有其他选择吗?

最佳答案

我认为 James 是 correct with his comment .只是 SunMSCAPIdoesn't support OAEP ,即使是 Windows 平台。 SunMSCAPI 不会释放私钥值,所以发生的情况是 Java 将搜索任何支持 OAEP 私钥对象的提供程序,然后找不到任何。这解释了初始异常:没有安装的提供程序支持此 key :sun.security.mscapi.RSAPrivateKey

请注意,声明“Java 不支持 OAEP”显然是错误的,因为 OAEP 是 even included as required algorithm .换句话说,如果没有 OAEP,您甚至不能将其称为 Java,事实上 SunJCE 提供程序确实包含对它的支持,包括对更多哈希函数和其他位大小的支持,而不仅仅是 1024 和 2048 位。但是,这确实需要与软件实现兼容的 key 。

关于java - 如何使用 SunMSCAPI key 解密 RSA-OAEP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59088372/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com