1.依赖

     <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk15on</artifactId><version>1.60</version></dependency>

2.工具类

package com.zykj.zycx.utils;/*import org.apache.commons.net.util.Base64;*/
import org.apache.commons.codec.binary.Base64;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;/*** @author lc* @version 1.0* @date 2022/3/21 10:57*/
public class AESUtil {static Logger logger = LoggerFactory.getLogger(AESUtil.class);// 密钥public static String key = "AD42F6697B035B7580E4FEF93BE20BAD"; // 32位private static String charset = "utf-8";// 偏移量private static int offset = 16;// 加密器类型:加密算法为AES,加密模式为CBC,补码方式为PKCS5Paddingprivate static String transformation = "AES/CBC/PKCS5Padding";// 算法类型:用于指定生成AES的密钥private static String algorithm = "AES";/*** 加密** @param content* @return*/public static String encrypt(String content) {return encrypt(content, key);}/*** 解密** @param content* @return*/public static String decrypt(String content) {return decrypt(content, key);}/*** 加密** @param content 需要加密的内容* @param key     加密密码(也可以自己直接用这个)* @return*/public static String encrypt(String content, String key) {try {//构造密钥SecretKeySpec skey = new SecretKeySpec(key.getBytes(), algorithm);//创建初始向量iv用于指定密钥偏移量(可自行指定但必须为128位),因为AES是分组加密,下一组的iv就用上一组加密的密文来充当IvParameterSpec iv = new IvParameterSpec(key.getBytes(), 0, offset);//创建AES加密器Cipher cipher = Cipher.getInstance(transformation);byte[] byteContent = content.getBytes(charset);//使用加密器的加密模式cipher.init(Cipher.ENCRYPT_MODE, skey, iv);// 加密byte[] result = cipher.doFinal(byteContent);//使用BASE64对加密后的二进制数组进行编码return new Base64().encodeToString(result);} catch (Exception e) {logger.info("", e);}return null;}/*** AES(256)解密** @param content 待解密内容* @param key     解密密钥* @return 解密之后* @throws Exception*/public static String decrypt(String content, String key) {try {SecretKeySpec skey = new SecretKeySpec(key.getBytes(), algorithm);IvParameterSpec iv = new IvParameterSpec(key.getBytes(), 0, offset);Cipher cipher = Cipher.getInstance(transformation);//解密时使用加密器的解密模式cipher.init(Cipher.DECRYPT_MODE, skey, iv);// 初始化byte[] result = cipher.doFinal(new Base64().decode(content));return new String(result); // 解密} catch (Exception e) {logger.info("解密异常:", e);}return null;}// 通过秘钥判断code是否正确public static boolean checkCode(String code, String key) {String decrypt = decrypt(code, key);if (decrypt != null) {return true;}return false;}// 随机生成32位字符串public static String generate32Str() {return RandomUtils.getItemID(32);}public static void main(String[] args) {String s = "BUSINESS_CARD";String key = generate32Str();System.out.println(key);String encryptResultStr = encrypt(s,key);// 加密System.out.println("加密前:" + s);System.out.println("加密后:" + encryptResultStr);// 解密System.out.println("解密后:" + decrypt(encryptResultStr, key));System.out.println("符合:" + checkCode(encryptResultStr, key));}}

3.枚举

package com.zykj.zycx.common.enums;import com.zykj.zycx.utils.AESUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;import java.security.Key;
import java.security.PrivateKey;
import java.util.Base64;/*** 商户key枚举** @author lc* @version 1.0* @date 2022/3/21 10:41*/
public enum  BusinessEnum {BUSINESS_CARD(3, "12s6z02yo6X1OjB458mb2E89d9bqDF1j", "adxyNQCC+Tf4HgQM1a6klw==");private Integer businessId;private String businessKey; // 加密的盐private String businessCode; // 加密后的code// 私有构造BusinessEnum(int businessId, String businessKey, String businessCode) {this.businessId = businessId;this.businessKey = businessKey;this.businessCode = businessCode;}// 通过key来校验codepublic static boolean checkCode(BusinessEnum businessEnum) {boolean check = AESUtil.checkCode(businessEnum.businessCode, businessEnum.businessKey);return check;}public static boolean checkCode(String businessCode, String businessKey) {boolean check = AESUtil.checkCode(businessCode, businessKey);return check;}}

通过自定义的key进行加密解密相关推荐

  1. csharp base64加密java解密_C#自定义基于Base64的加密解密类

    下面是编程之家 jb51.cc 通过网络收集整理的代码片段. 编程之家小编现在分享给大家,也给大家做个参考. using System; using System.Security.Cryptogra ...

  2. RSA分段加密/解密 nodejs 和java联调

    RSA分段加密/解密 nodejs 和java联调 文章目录 RSA分段加密/解密 nodejs 和java联调 1 nodejs 环境 1.1 axios配置 1.2 API接口 1.3 业务 1. ...

  3. Go加密解密之DES

    一.DES简介 DES(Data Encryption Standard)是对称加密算法,也就是加密和解密用相同的密钥.其入口参数有三个:key.data.mode.key为加密解密使用的密钥,dat ...

  4. 白话 discuz加密解密算法,包你懂

    今天和大家分享一下discuz的加密和解密算法 研究了一个星期了, 总结了这个 算法有三个特点 1,动态性,同一字符串每次加密的密文都不一样 2,时间性,可以自己加一个限期参数,以秒为单位 3,统一性 ...

  5. java使用DES加密方式,实现对数据的加密解密

    全栈工程师开发手册 (作者:栾鹏) java教程全解 java使用DES加密方式,实现对数据的加密解密.加密和解密中需要使用同一个秘钥 第一种方式,使用类型Key作为加密解密的共同秘钥. 测试代码 p ...

  6. 加密解密系统研究毕业论文

    加密解密系统研究毕业论文     摘要: DES算法DES算法为密码体制中的对称密码体制,又被成为美国数据加密标准 题       目 加密解密系统研究 学       院 台州广播电视大学 专    ...

  7. 各种加密解密函数(URL加密解密、sha1加密解密、des加密解密)

    普通hash函数如md5.sha1.base64等都是不可逆函数.虽然我们利用php可以利用这些函数写出可逆函数来.但是跨语言时这类可逆函数非常难搞定.所以这时尽量使用AES DES RC4 Rabb ...

  8. 使用DES算法实现加密解密

    使用DES算法实现加密解密 我们常见的加密算法有DES.MD5.IDEA.AES等等,这篇随笔介绍使用DES算法实现加密解密 首先介绍一下DES算法: DES算法为密码体制中的对称密码体制,又被称为美 ...

  9. 【Kotlin】加密解密2:DES、AES加密和解密

    文章目录 Api文档 DES加密解密 Base64加密和解密 AES加密解密 DES和AES密钥长度 工作模式和填充模式 对称加密的应用场景 Api文档 https://docs.oracle.com ...

最新文章

  1. CString工作原理和常见问题分析
  2. hiveserver2启动不起来_一辆顶杆机电启动很响,不好打火,有时空挡指示灯较暗...
  3. 左神算法:将搜索二叉树转换成双向链表(Java版)
  4. M. Monster Hunter(树形dp)
  5. Diango博客--7.自动生成文章摘要
  6. 无源波分和彩光模块_纯无源粗波分复用器(CWDM)部署4/5G网络,节省光缆资源...
  7. 鸿蒙os开启第二批公测,鸿蒙OS开启第二批公测,7款机型加入升级名单,NOVA用户恭喜了...
  8. 域名解析到指定端口_南京课工场IT培训:搭建nginx虚拟主机——基于域名、端口和IP...
  9. html5 input step,HTML5 Data Input 元素介绍
  10. box-sizing属性的理解
  11. 怎么从零开始自己做网站?
  12. 关于Android中开机启动服务
  13. 【2022年第十周周总结】拖延症啊。。。。算法题啊。。。。
  14. 域名服务器有什么作用?怎么查询域名服务器地址?
  15. 服务器导出表为dmp文件,mysql数据库导出dmp文件
  16. Android APP开发入门
  17. 360网站卫士常用前端公共库CDN服务
  18. 在线听书有声小说网站详细安装教程
  19. 这7点不去做外汇交易难爆仓
  20. iOS 集成FaceId和TouchID

热门文章

  1. 计算机公共基础知识(N-S图,DFD图,PAD图,程序流程图,E-R图)
  2. python代理ip怎么写_python代理ip怎么写
  3. Excel系列教程(1):如何自动填充单元格
  4. 数学建模之储药柜的设计
  5. 虚拟机RedHatLinux9安装Oralce92全过程
  6. 华为ESNP,路由器和交换机连接电脑不同网段的解决方法。
  7. UI5-文档-4.5-Controllers
  8. 用Python画小猪佩奇
  9. 遗传算法关于多目标优化python(详解)
  10. Codeforces Round #703 (Div. 2) C. Guessing the Greatest