Java读取OpenSSL生成的PEM公钥文件

JDK8的JCE是不支持读取PEM文件的。需要使用bouncycastle。
项目需求,使用SHA1WithRSA算法,对接口数据做签名。代码如下:

@Service
class SignService {
   
    private static Logger LOG = LoggerFactory.getLogger(SignService.class);

    @Autowired
    private Config config;

    private Signature signature;

    @PostConstruct
    private void init() {
   
        try {
   
            PKCS8EncodedKeySpec priKeySpec = new PKCS8EncodedKeySpec(
                    getDecoder().decode(config.getPrivateKey().getBytes(ISO_8859_1)));

            KeyFactory factory = KeyFactory.getInstance("RSA");
            PrivateKey privateKey = factory.generatePrivate(priKeySpec);

            signature = Signature.getInstance("SHA1WithRSA");
            signature.initSign(privateKey);

        } catch (NoSuchAlgorithmException |
                /*InvalidAlgorithmParameterExcep
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
读取SM2的PEM文件中的公钥,可以使用Bouncy Castle库。以下是使用Bouncy Castle库读取SM2 PEM文件中的公钥Java代码示例: ```java import java.io.FileReader; import java.security.KeyFactory; import java.security.Security; import java.security.interfaces.ECPublicKey; import java.security.spec.X509EncodedKeySpec; import org.bouncycastle.asn1.x9.X9ECParameters; import org.bouncycastle.jcajce.provider.asymmetric.ec.BCECPublicKey; import org.bouncycastle.jce.provider.BouncyCastleProvider; import org.bouncycastle.openssl.PEMParser; import org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter; public class SM2PublicKeyReader { public static void main(String[] args) throws Exception { Security.addProvider(new BouncyCastleProvider()); // 读取PEM文件 FileReader fileReader = new FileReader("sm2.pem"); PEMParser pemParser = new PEMParser(fileReader); // 解析PublicKey JcaPEMKeyConverter converter = new JcaPEMKeyConverter().setProvider("BC"); Object object = pemParser.readObject(); X509EncodedKeySpec keySpec = new X509EncodedKeySpec(converter.getPublicKey((BCECPublicKey) object).getEncoded()); ECPublicKey publicKey = (ECPublicKey) KeyFactory.getInstance("EC", "BC").generatePublic(keySpec); // 获取公钥参数 X9ECParameters ecParams = ((BCECPublicKey) publicKey).getParameters(); // 使用公钥进行加解密等操作 // ... pemParser.close(); } } ``` 注意,这里的`sm2.pem`文件只包含公钥。解析出来的公钥类型为`ECPublicKey`。您还可以使用`getParams()`方法获取公钥的参数。在此示例中,我们使用`X9ECParameters`类型来获取公钥的参数。 如果您想要读取PEM文件中的私钥,请参考我之前的回答。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值