当前位置: 首页 > news >正文

java实现AES256对称加解密工具类

一、引入依赖包

  • 引入相关依赖包

    <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk15on</artifactId><version>1.70</version>
    </dependency>
    <!--lombok用于简化实体类开发-->
    <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional>
    </dependency>
    

二、AES256对称加解密工具类

  • AES256对称加解密工具类代码

    package com.xz.util;import lombok.extern.slf4j.Slf4j;
    import org.bouncycastle.jce.provider.BouncyCastleProvider;
    import org.bouncycastle.util.encoders.Base64;import javax.crypto.Cipher;
    import javax.crypto.spec.SecretKeySpec;
    import java.nio.charset.StandardCharsets;
    import java.security.Security;/*** @author: xz* @since: 2024/1/11 23:03* @description:*/
    @Slf4j
    public class AES256Util {/*** 32位长度随机密码key*/private static final String PASSWORD = "MEqLCnG2Q0IfauMDbZq1lP46uP4BHsiv";/*** AES256加密* @param content* @return*/public static String encrypt(String content) {try {if(content == null) {return "";}//根据给定的字节数组构造一个密钥。enCodeFormat:密钥内容;"AES":与给定的密钥内容相关联的密钥算法的名称SecretKeySpec key = new SecretKeySpec(PASSWORD.getBytes(StandardCharsets.UTF_8), "AES");//将提供程序添加到下一个可用位置Security.addProvider(new BouncyCastleProvider());//创建一个实现指定转换的 Cipher对象,该转换由指定的提供程序提供。//"AES/ECB/PKCS7Padding":转换的名称;"BC":提供程序的名称Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");cipher.init(Cipher.ENCRYPT_MODE, key);byte[] byteContent = content.getBytes("utf-8");byte[] cryptograph = cipher.doFinal(byteContent);return new String(Base64.encode(cryptograph));} catch (Exception e) {log.error("AES256 加密失败:", e.getMessage());}return null;}/*** AES256解密* @param cryptograph* @return*/public static String decrypt(String cryptograph) {try {if(cryptograph == null) {return "";}SecretKeySpec key = new SecretKeySpec(PASSWORD.getBytes(StandardCharsets.UTF_8), "AES");Security.addProvider(new BouncyCastleProvider());Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");cipher.init(Cipher.DECRYPT_MODE, key);byte[] content = cipher.doFinal(Base64.decode(cryptograph));return new String(content);} catch (Exception e) {log.error("AES256 解密失败:", e.getMessage());}return null;}
    }
    

三、测试类

  • 测试代码

    package com.xz.util;
    /*** @author: xz* @since: 2024/1/11 23:07* @description:*/
    public class AES256UtilTest {public static void main(String[] args) {String str="hello 编号 007!";System.out.println("原始内容:"+str);String encrypt = AES256Util.encrypt(str);System.out.println("加密后的内容:"+encrypt);String decrypt = AES256Util.decrypt(encrypt);System.out.println("解密后的内容:"+decrypt);}
    }
    
  • 测试输出结果
    在这里插入图片描述

http://www.lryc.cn/news/278385.html

相关文章:

  • 其他排序(基数排序,希尔排序和桶排序)(数据结构课设篇3,python版)(排序综合)
  • 【复现】DiffTalk
  • SQLServer 系统概述
  • Vue3 + TS + Element-Plus —— 项目系统中封装表格+搜索表单 十分钟写五个UI不在是问题
  • Linux系统——测试端口连通性方法
  • Python虚拟环境轻松配置:Jupyter Notebook中的内核管理指南
  • 大数据-hive函数与mysql函数的辨析及练习-将多行聚合成一行
  • 【AI视野·今日NLP 自然语言处理论文速览 第七十三期】Tue, 9 Jan 2024
  • vue知识-03
  • 关于httpClient 使用的注意事项
  • Docker 发布自定义镜像到公共仓库
  • 程序员有哪些接单的渠道?
  • 服务容错-熔断策略之断路器hystrix-go
  • C++进阶(三)多态
  • 大众汽车宣布将ChatGPT,批量集成在多种汽车中!
  • React----函数组件和类组件
  • Kafka集群部署 (KRaft模式集群)
  • Vue 自定义仿word表单录入之日期输入组件
  • Oracle与Java JDBC数据类型对照
  • C++力扣题目226--翻转二叉树
  • Gorm 数据库表迁移与表模型定义
  • 系列三、Spring Security中自定义用户名/密码
  • 如何顺滑使用华为云编译构建平台?
  • 查看Linux磁盘空间
  • 2023年全国职业院校技能大赛(高职组)“云计算应用”赛项赛卷⑩
  • vim基本操作命令
  • mybatis-plus实现真正的批量插入
  • pytorch12:GPU加速模型训练
  • P1603 斯诺登的密码题解
  • YOLOv8 + openVINO 多线程数据读写顺序处理