JAVA加解密之AES
<!--AES加密--> <dependency> <groupId>org.bouncycastle</groupId> <artifactId>bcprov-ext-jdk16</artifactId> <version>1.45</version> </dependency>
工具类
AesUtil.java
import lombok.extern.slf4j.Slf4j; import org.apache.commons.codec.binary.Base64; import org.bouncycastle.jce.provider.BouncyCastleProvider; import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; import java.nio.charset.StandardCharsets; import java.security.Security; /** * @author 。 * @description AesUtil工具类 **/ @Slf4j public class AesUtil { /** * 初始化PKCS7Padding使用 */ static { Security.addProvider(new BouncyCastleProvider()); } /** * 加密类型 */ private static final String KEY_ALGORITHM = "AES"; /** * 密码器设置 */ private static final String DEFAULT_CIPHER_ALGORITHM = "AES/ECB/PKCS7Padding"; /** * AES加密 * * @param content 需要加密的字符串 * @param key 字符长度必须为16, 24, 32 * @return 返回Base64转码后的加密数据 */ public static String encrypt(String content, String key) throws Exception { // 创建密码器 Cipher cipher = Cipher.getInstance(DEFAULT_CIPHER_ALGORITHM); byte[] byteContent = content.getBytes(StandardCharsets.UTF_8); // 初始化为加密模式的密码器 cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), KEY_ALGORITHM)); // 加密 byte[] result = cipher.doFinal(byteContent); //通过Base64转码返回 String s = Base64.encodeBase64String(result); return s; } /** * AES解密 * * @param encrypted 已加密的密文 * @param key 字符长度必须为16, 24, 32 * @return 返回解密后的数据 */ public static String decrypt(String encrypted, String key) throws Exception { //实例化 Cipher cipher = Cipher.getInstance(DEFAULT_CIPHER_ALGORITHM); //使用密钥初始化,设置为解密模式 cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), KEY_ALGORITHM)); //执行操作 byte[] result = cipher.doFinal(Base64.decodeBase64(encrypted)); String s = new String(result, StandardCharsets.UTF_8); return s; } }
使用 示例
public static void main(String[] args) throws Exception { String content = "你好啊"; System.out.println("加密前: " + content); String encryptContent = AesUtil.encrypt(content, "111"); System.out.println("加密后:" + encryptContent); String decryptContent = AesUtil.decrypt(encryptContent, "111"); ; System.out.println("解密后:" + decryptContent); }
JS加解密之AES:https://www.cnblogs.com/pxblog/p/17070480.html
-----------------------有任何问题可以在评论区评论,也可以私信我,我看到的话会进行回复,欢迎大家指教------------------------
(蓝奏云官网有些地址失效了,需要把请求地址lanzous改成lanzoux才可以)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2021-01-28 Linux(Centos)配置vsftp使用账号密码(虚拟用户)登录ftp进行文件上传和修改
2020-01-28 springboot整合阿里云视频点播接口
2020-01-28 HttpServletResponse工具类和HttpServletRequest工具类,前台参数接收方式和后台返回(JSON)数据格式