6.Java开源SM2非对称加密算法实现

文章介绍了Java中使用BouncyCastle库实现SM2非对称加密算法的过程,包括加解密核心逻辑、秘钥生成与转换。SM2算法基于椭圆曲线,支持多种秘钥生成方式,具有较高的加密效率。同时,文章提到了与RSA算法的对比以及在国密改造场景中的局限性。

6.Java开源SM2非对称加密算法实现

前期内容导读:

  1. Java开源RSA/AES/SHA1/PGP/SM2/SM3/SM4加密算法介绍
  2. Java开源AES/SM4/3DES对称加密算法介绍及其实现
  3. Java开源AES/SM4/3DES对称加密算法的验证说明
  4. Java开源RSA/SM2非对称加密算法对比介绍
  5. Java开源RSA非对称加密算法实现

1. 开源组件 非对称秘钥加密介绍

  • 加密组件引入方法:
    <dependency>
        <groupId>com.biuqu</groupId>
        <artifactId>bq-encryptor</artifactId>
        <version>1.0.5</version>
    </dependency>
    

1.1 SM2的加解密实现

  • 加解密核心逻辑
    public byte[] doCipher(byte[] data, byte[] key, int cipherMode)
    {
         
         
        SM2Engine.Mode mode = SM2Engine.Mode.C1C2C3;
        if (!this.getPaddingMode().equalsIgnoreCase(String.valueOf(DEFAULT_MODE)))
        {
         
         
            mode = SM2Engine.Mode.C1C3C2;
        }
    
        SM2Engine sm2Engine = new SM2Engine(mode);
    
        this.initSm2Engine(sm2Engine, key, cipherMode);
    
        try
        {
         
         
            return sm2Engine.processBlock(data, 0, data.length);
        }
        catch (Exception e)
        {
         
         
            throw new EncryptionException("failed to do sm2 cipher.", e);
        }
    }
    
    private void initSm2Engine(SM2Engine sm2Engine, byte[] key, int cipherMode)
    {
         
         
        if (Cipher.ENCRYPT_MODE == cipherMode)
        {
         
         
            ECPublicKey keyObj = (ECPublicKey)this.toPubKey(key);
            ECDomainParameters domainParam = this.getDomainParam(keyObj);
            ECKeyParameters keyParam = new ECPublicKeyParameters(keyObj.getQ(), domainParam);
            byte[] initKey = UUID.randomUUID().toString().getBytes(StandardCharsets.UTF_8);
            sm2Engine.init(true, new <
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值