java实现国密SM4加密「建议收藏」

java实现国密SM4加密「建议收藏」前言最近世界政治影响,我国也开始要求算法的使用,以避免来自外国的黑客入侵。我们在使用加密算法时,有必要选择使用国密算法进行加密一、国密SM4是什么? 国密即国家密码局认定的国产密码算法。 主要有SM1,SM2,SM3,SM4。密钥长度和分组长度均为128位。 SM1为对称加密。其加密强度与AES相当。该算法不公开,调用该算法时,需要通过加密芯片的接口进行调用。 SM2为非对称加密,基于ECC。该算法已公开。由于该算法基于ECC,故其签名速度与秘钥生成速度都快于RSA ECC2.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用


前言

在这里插入图片描述

最近世界政治影响,我国也开始要求算法的使用,以避免来自外国的黑客入侵。我们在使用加密算法时,有必要选择使用国密算法进行加密


一、国密SM4是什么?

	国密即国家密码局认定的国产密码算法。
	
	主要有SM1,SM2,SM3,SM4。密钥长度和分组长度均为128位。
	SM1 为对称加密。其加密强度与AES相当。该算法不公开,调用该算法时,需要通过加密芯片的接口进行调用。
	
	SM2为非对称加密,基于ECC。该算法已公开。由于该算法基于ECC,故其签名速度与秘钥生成速度都快于RSA
	ECC 256位(SM2采用的就是ECC 256位的一种)安全强度比RSA 2048位高,但运算速度快于RSA。
	
	SM3 消息摘要。可以用MD5作为对比理解。该算法已公开。校验结果为256位。
	
	SM4 无线局域网标准的分组数据算法。对称加密,密钥长度和分组长度均为128位。

二、使用步骤

1.引入hutool依赖

Hutool借助Bouncy Castle库可以支持国密算法

<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.4.5</version>
</dependency>
<dependency>
    <groupId>org.bouncycastle</groupId>
    <artifactId>bcprov-jdk15on</artifactId>
    <version>1.58</version>
</dependency>

2.示例代码

2.1 使用秘钥

import cn.hutool.crypto.symmetric.SymmetricCrypto;

public class sm4Demo { 
   

    //key必须是16字节,即128位
    final static String key = "sm4demo123456789";

    //指明加密算法和秘钥
    static SymmetricCrypto sm4 = new SymmetricCrypto("SM4/ECB/PKCS5Padding", key.getBytes());

    //加密为16进制,也可以加密成base64/字节数组
    public static String encryptSm4(String plaintext) { 
   
        return sm4.encryptHex(plaintext);
    }

    //解密
    public static String decryptSm4(String ciphertext) { 
   
        return sm4.decryptStr(ciphertext);
    }

    public static void main(String[] args) { 
   
        String content = "hello sm4";
        String plain = encryptSm4(content);
        String cipher = decryptSm4(plain);
        System.out.println(plain + "\n" + cipher);
    }
}

2.2 不使用秘钥

构造SymmetricCrypto 对象时,不传秘钥即可。

SymmetricCrypto sm4 = new SymmetricCrypto("SM4/ECB/PKCS5Padding");

2.3 使用SmUtil快速创建SymmetricCrypto对象

//不带秘钥
SymmetricCrypto sm4 = SmUtil.sm4();

//带秘钥
String key = "1234567812345678";
SymmetricCrypto sm4 = SmUtil.sm4(key.getBytes());

三、API介绍

3.1 加密方法

SymmetricCrypto 类方法 返回类型
encrypt (byte[] data) byte[]
encrypt (String data,Charset charset) byte[]
encryptBase64(byte[] data) String
encrypt(Inputstream data) byte[]
encrypt (String data) byte[]
encrypt (String data,String charset) byte[]
encryptBase64(String data) String
encryptBase64(InputStream data) String
encryptBase64(String data,String charset) String
encryptBase64(String data,Charset charset) String
encryptHex (byte[] data) String
encryptHex (String data) String
encryptHex (Inputstream data) String
encryptHex(String data,string charset) String
encryptHex (String data,Charset charset) String

3.2 解密方法

SymmetricCrypto 类方法 返回类型
decryptstr (String data) String
decryptstr (byte[] bytes,Charset charset) String
decrypt (byte[] bytes)) byte[]
decrypt (String data) byte[]
decryptstr (byte[] bytes) String
decrypt (InputStream data) byte[]
decryptStr (InputStream data) String
decryptstr (String data,Charset charset) String
decryptstr (String data,Charset charset) String

总结

SymmetricCrypto类的构造方法非常灵活,可以灵活根据自己需要的方式进行构造

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/185668.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月5日 下午2:46
下一篇 2022年10月5日 下午3:00


相关推荐

  • 教你读懂蛋白质数据库文件(PDB文件)

    教你读懂蛋白质数据库文件(PDB文件)回答网友提问:什么是HETATM?  并教你读懂蛋白质的PDB文件  作者:小米HETATM非标准基团原子坐标,这个是PDB数据库原子坐标的一种记录格式。如HETATM460PPO4100-2.5027.5874.2251.0024.59PHETATM461O1PO4100-3.3206.5325.0031.00

    2022年6月2日
    42
  • Anconda和Jupyter和Pycharm安装使用详解

    Anconda和Jupyter和Pycharm安装使用详解文章目录 1 本文概述 2 什么是 Anaconda3 为什么要使用 Anaconda3 1 使用方便 3 2 管理方便 4Anaconda 安装 4 1 到 Anaconda 官网下载安装包 4 2 开始安装 5Anaconda 使用 5 1 概述 5 2conda5 2 1 启动 conda5 2 2conda 环境管理 5 2 3conda 包管理 5 2 4Conda 使用国内源 6JupyterNote 1JupyterNote 介绍 6 2jupyternote 使用 6 2 1 打开 jupy

    2026年3月18日
    2
  • 超级详细的Lua语言的基础教程

    超级详细的Lua语言的基础教程由于编写测试脚本 不光 Python 好用 Lua 也很好用 整理了一下 Lua 的基础教程 有需要的可以了解一下 以下是自己总结出来的 lua 数据类型 lua 是动态类型语言 变量不需要类型定义 可直接赋值 值可以存储在变量中 作为参数传递或结果返回 lua 中有 8 个基本类型分别为 nil boolean number string userdata function thread 和 table 数据类型描述 nil 这个最简单 只有值 nil 属于该类 表示一个无效值 在条件表达式中相当

    2026年3月17日
    2
  • 文件指纹算法

    文件指纹算法一直在找 robinhash 的指纹算法折腾了很久终于解决问题了 因为 java 实现的源码被我找到了 我改成了 c 版本希望对和我有相同问题的朋友有所帮助 大家有更好的可以提出来阿头文件 nbsp rabinhash c hCreatedon Mar31 2009 Author luo 由 SeanOwen 写的 java 版本改编而

    2026年3月20日
    1
  • CSS3橙色的星球绕轨道公转动画

    效果:http://hovertree.com/texiao/css3/24/效果图:代码如下:转自:http://hovertree.com/h/bjaf/css3xingxi.htm特效汇总:

    2021年12月24日
    55
  • SVN的学习.SVN的使用方式!TortoiseSVN以及TortoiseSVN汉化包下载和使用!

    一.SVN是什么:SVN是Subversion的简称,是一个开放源代码的版本控制系统,说得简单一点SVN就是用于多个人共同开发同一个项目,共用资源的目的。二.SVN的工作流程:集中式管理的工作流程:集中式代码管理的核心是服务器,所有开发者在开始新一天的工作之前必须从服务器获取代码,然后开发,最后解决冲突,提交。所有的版本信息都放在服务器上。如果脱离了服务器,开发者…

    2022年4月10日
    36

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号