资源简介
对称加密AES算法,实现前后端加密解密,前端使用cryptojs.js实现,后端使用java实现
代码片段和文件信息
package com.example.common.util;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.security.Key;
import java.security.spec.AlgorithmParameterSpec;
import java.util.base64;
/**
* 对称加密解密AES算法
*
* @author zhaors
*/
public class AESUtils {
private static final String TRANSFORMATION = “AES/CBC/PKCS5Padding“;
private static final String ALGORITHM = “AES“;
private static final String CHARSET = “utf-8“;
/**
* 建议为16或者32位
*/
private static final String KEY = “A-16-Byte-keyVal“;
/**
* 必须16位
* 初始化向量IV不可以为32位,否则异常java.security.InvalidAlgorithmParameterException: Wrong IV length: must be 16 bytes long
*/
private static final String IV = “A-16-Byte-String“;
/**
* 加密
*
* @param context
* @return
*/
public static String encrypt(String context) {
try {
byte[] decode = context.getBytes(CHARSET);
byte[] bytes = createKeyAndIv(decode Cipher.ENCRYPT_MODE);
return base64.getEncoder().encodeToString(bytes);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
/**
* 解密
*
* @param context
* @return
*/
public static String decrypt(String context) {
try {
base64.Decoder decoder = base64.getDecoder();
byte[] decode = decoder.decode(context);
byte[] bytes = createKeyAndIv(decode Cipher.DECRYPT_MODE);
return new String(bytes CHARSET);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
/**
* 获取key & iv
*
* @param context
* @param opmode
* @return
* @throws Exception
*/
public static byte[] createKeyAndIv(byte[] context int opmode) throws Exception {
byte[] key = KEY.getBytes(CHARSET);
byte[] iv = IV.getBytes(CHARSET);
return cipherFilter(context opmode key iv);
}
/**
* 执行操作
*
* @param context
* @param opmode
* @param key
* @param iv
* @return
* @throws Exception
*/
public static byte[] cipherFilter(byte[] context int opmode byte[] key byte[] iv) throws Exception {
Key secretKeySpec = new SecretKeySpec(key ALGORITHM);
AlgorithmParameterSpec ivParameterSpec = new IvParameterSpec(iv);
Cipher cipher = Cipher.getInstance(TRANSFORMATION);
cipher.init(opmode secretKeySpec ivParameterSpec);
return cipher.doFinal(context);
}
/**
* 主方法测试
*
* @param args
*/
public static void main(String[] args) {
String context = “zhaors“;
System.out.println(“元数据“ + context);
String encrypt = encrypt(context);
System.out.println(“加密之后:“ + encrypt);
String decry
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 3204 2018-07-06 15:57 cryptojs\AESUtils.java
文件 191936 2016-12-14 20:00 cryptojs\crypto-js.js
文件 1255 2018-07-05 18:18 cryptojs\node_test.js
文件 2039 2018-07-05 17:42 cryptojs\test.html
目录 0 2018-07-06 15:47 cryptojs
----------- --------- ---------- ----- ----
198434 5
- 上一篇:飞机大战Java源代码
- 下一篇:javaweb学生选课系统课程设计
相关资源
- javaweb学生选课系统课程设计
- 飞机大战Java源代码
- javaweb有关外文文献
- 基于Java技术的食品团购网的设计与实
-
org.springfr
amework.beans-3.1.0.RELEASE.jar - java rsa非对称加密算法3个源代码
- n阶幻方java代码
- java数据结构校园导游咨询系统
- Java云计算简单
- vote投票系统java jsp mysql
- matlabcontrol-4.1.0java中调用matlab代码ja
- java实现KMeans算法代码
- DBUtil工具类,java,mysql
- 全国交通咨询系统数据结构课设 图的
- 基于javaf808协议网关模拟器
- Java+SQLServer学生成绩管理系统代码+数
- 九九乘法表
- java经典50例题
- 基于赤字轮询的mm3队列模拟java代码
- JAVA 模拟时钟实验报告
- Java拼图游戏代码
- java2cpp java转C++
- 银行账户管理系统java程序编写
- Java拼写检查
- fpgrowth算法java源码
- Java实现圆圈旋转效果,等待、加载、
- JAVA C/S架构应用程序
- Java解析CSV文件
- 一个简易版坦克大战 供java初学者学
- 教学管理系统代码java
评论
共有 条评论