国密SM2,SM3,SM4在BC上的实现(一)

本文介绍了如何在BC(Bouncy Castle)框架上实现国密SM2、SM3和SM4算法,包括MAC、密钥生成、加解密、签名和数字证书的创建。特别地,文章讨论了SM2在PDF数字签名中的应用,并提供了项目结构图。
摘要由CSDN通过智能技术生成

SM2,SM3,SM4算法的实现在网络上实现有不少,但是实现只是加解密,签名等,如果说要生成国密数字证书就麻烦了,还有最近银行的项目上需要用ITEXT对pdf进行国密跟RSA证书数字签名,这个用SM2单独的签名是不能实现的,因为ITEXT签名是基于BC框架的,这里就是在BC框架上添加SM2,SM4算法,以及SM3摘要算法,在这里跟大家分享一下。
BC框架是基于JCA,JCE来实现的,关于JCA,JCE这里就不详述了。既然我们要添加这几种算法,我们要实现那几步呢?
1,实现MAC
2,实现SM2,SM3,SM4算法
3,SM2,SM4算法的密钥(KeyPairGenerator)
4,加解密(Cipher);
5,签名(Signature);
6,数字证书(Certificate)
话不多说,先上几张效果图。
一 ,SM2加解密
结果图

 public static String SM2_Cipher(boolean all,String enData) throws NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException, BadPaddingException, IllegalBlockSizeException {
        StringBuilder sb = new StringBuilder();
        byte[] sourceData = enData.getBytes();
        KeyPair keyPair = generateKeyPair(all?sb:null);
        Cipher cp1 = Cipher.getInstance("SM2");
        sb.append("public key = ");
        sb.append(bytesToHexString(keyPair.getPublic().getEncoded()));
        sb.append("\nprivate key = ");
        sb.append(bytesToHexString(keyPair.getPrivate().getEncoded()));
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值