java der格式_用Java读取OpenSSL生成的,PEM / DER格式的S / MIME消息

以下是使用BouncyCastle 1.57(受this article启发)解密的方法:

import org.bouncycastle.cms.CMSEnvelopedData;

import org.bouncycastle.cms.CMSException;

import org.bouncycastle.cms.KeyTransRecipientInformation;

import org.bouncycastle.cms.RecipientInformation;

import org.bouncycastle.cms.jcajce.JceKeyTransEnvelopedRecipient;

import org.bouncycastle.cms.jcajce.JceKeyTransRecipient;

import org.bouncycastle.util.encoders.Base64;

import java.security.KeyFactory;

import java.security.NoSuchAlgorithmException;

import java.security.PrivateKey;

import java.security.spec.InvalidKeySpecException;

import java.security.spec.PKCS8EncodedKeySpec;

import java.util.Collection;

public class PKCS7Decryptor {

private PrivateKey privateKey;

public PKCS7Decryptor(String privateKeyStr) {

try {

byte[] privateKeyData = extractRawData(privateKeyStr, "PRIVATE KEY");

PKCS8EncodedKeySpec kspec = new PKCS8EncodedKeySpec(privateKeyData);

KeyFactory kf = KeyFactory.getInstance("RSA");

privateKey = kf.generatePrivate(kspec);

} catch (NoSuchAlgorithmException | InvalidKeySpecException e) {

throw new RuntimeException("Unable to parse private key");

}

}

public String decrypt(String encryptedText) throws CMSException {

byte[] data = extractRawData(encryptedText, "PKCS7");

CMSEnvelopedData envelopedData = new CMSEnvelopedData(data);

Collection recipients = envelopedData.getRecipientInfos().getRecipients();

KeyTransRecipientInformation recipientInfo = (KeyTransRecipientInformation) recipients.iterator().next();

JceKeyTransRecipient recipient = new JceKeyTransEnvelopedRecipient(privateKey);

return new String(recipientInfo.getContent(recipient));

}

private byte[] extractRawData(String text, String dataType) {

return Base64.decode(text

.replace(String.format("-----BEGIN %s-----", dataType), "")

.replace(String.format("-----END %s-----", dataType), ""));

}

}

一些解释:

在类构造函数中,私钥被转换为适当的格式

页眉和页脚(如"-----BEGIN PKCS7-----")将被删除,内容将进行base64解码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值