【Java / JavaScript】AES加密解密
Java封装的AES加密解密工具类:
几个重要的参数信息
- 需要指定一个密钥串sKey 密钥内容自定义 数字 + 字母 + 特殊符号
- 加密方式为 AES
- AES下面的模式ECB
- ECB下面指定内嵌内容为PKCS5
package cn.hyite.amerp.common.util; import java.util.Base64; import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec; public class EncryptAESUtil { public static String sKey = "加密的密钥串,自定义"; public static String Encrypt(String sSrc) {
byte[] raw;
try {
raw = sKey.getBytes("utf-8");
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
byte[] encrypted = cipher.doFinal(sSrc.getBytes("utf-8"));
return Base64.getEncoder().encodeToString(encrypted);
} catch (Exception e) {
e.printStackTrace();
return null;
}
} // 解密
public static String Decrypt(String sSrc) {
try {
byte[] raw = sKey.getBytes("utf-8");
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, skeySpec);
byte[] encrypted1 = Base64.getDecoder().decode(sSrc);
try {
byte[] original = cipher.doFinal(encrypted1);
String originalString = new String(original, "utf-8");
return originalString;
} catch (Exception e) {
e.printStackTrace();
return null;
}
} catch (Exception ex) {
ex.printStackTrace();
return null;
}
}
}
工具测试方法:
public static void main(String[] args) throws Exception {
// 需要加密的字串
String cSrc = "999999";
System.out.println(cSrc); // 加密
String enString = EncryptAESUtil.Encrypt(cSrc);
System.out.println("加密后的字串是:" + enString); // 解密
String DeString = EncryptAESUtil.Decrypt(enString);
System.out.println("解密后的字串是:" + DeString);
}
JavaScript的AES加密解密工具类:
参考博客:
https://www.cnblogs.com/herenwei-wayne/p/15832466.html
安装CryptoJS组件,先在NPM官网上找到CryptoJS的依赖地址:
https://www.npmjs.com/package/crypto-js
测试方法编写:
import Crypto from 'crypto-js' test() {
const serverKey = 'cloud9.aesde.2023'
const key = Crypto.enc.Utf8.parse(serverKey)
const iv = Crypto.enc.Utf8.parse(serverKey) // 生成密文
let encryptedData = Crypto.AES.encrypt('需要被加密的明文', key, {
iv: iv,
mode: Crypto.mode.ECB,
padding: Crypto.pad.Pkcs7
})
encryptedData = encryptedData.toString()
console.log(encryptedData) const decryptedData = Crypto.AES.decrypt(encryptedData, key, {
iv: iv,
mode: Crypto.mode.ECB,
padding: Crypto.pad.Pkcs7
}) // 解密后的明文
console.log(decryptedData.toString(Crypto.enc.Utf8))
}
测试加密的密文和Java解密能一致之后,我们开始封装方法(aes-util.js):
import Crypto from 'crypto-js' /**
* 参考:Java JavaScript AES/CBC/PKCS5Padding 加密解密
* https://www.cnblogs.com/herenwei-wayne/p/15832466.html
*
* crypto-js依赖 npm地址
* https://www.npmjs.com/package/crypto-js?activeTab=readme
*
*/
const serverKey = 'cloud9.aesde.2023' const key = Crypto.enc.Utf8.parse(serverKey)
const iv = Crypto.enc.Utf8.parse(serverKey) /**
* 使用AES的(ECB模式)(Pkcs7内嵌)算法进行加密
* @param plainText 明文
* @returns {string} 密文
*/
const encryptByEcbPkcs7 = plainText => {
const encryptedData = Crypto.AES.encrypt(plainText, key, {
iv: iv,
mode: Crypto.mode.ECB,
padding: Crypto.pad.Pkcs7
})
return encryptedData.toString()
} /**
* 使用AES的(ECB模式)(Pkcs7内嵌)算法进行解密
* @param cipherText 密文
* @returns {string} 明文
*/
const decryptByEcbPkcs7 = cipherText => {
const decryptedData = Crypto.AES.decrypt(cipherText, key, {
iv: iv,
mode: Crypto.mode.ECB,
padding: Crypto.pad.Pkcs7
})
return decryptedData.toString(Crypto.enc.Utf8)
} /**
* 按对象集中导出
*/
export {
encryptByEcbPkcs7,
decryptByEcbPkcs7
}
JS加密与Java解密:
调用时引入需要的方法:
import { encryptByEcbPkcs7 } from '@/utils/encrypt/aes-util' // 调用时方法
param.password = encryptByEcbPkcs7(param.password)
传入后台解码:
String DeString = EncryptAESUtil.Decrypt(enString);
【Java / JavaScript】AES加密解密的更多相关文章
- java使用AES加密解密 AES-128-ECB加密
java使用AES加密解密 AES-128-ECB加密 import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; impo ...
- php与java通用AES加密解密算法
AES指高级加密标准(Advanced Encryption Standard),是当前最流行的一种密码算法,在web应用开发,特别是对外提供接口时经常会用到,下面是我整理的一套php与java通用的 ...
- [Java 实现AES加密解密]
今天同学请教我这个问题,被坑了次…… 实现的功能是2个Java类:一个读取源文件生成加密文件,另一个类读取加密文件来解密. 整个过程其实很简单,java有AES的工具包,设好秘钥,设好输入内容,就得到 ...
- 使用java进行 AES 加密 解密?
百度百科是这样定义的: 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标 ...
- Java使用AES加密解密
AES加密机制: 密码学中的高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准. 这个标准用来替代原先的 ...
- 【java】AES加密解密|及Base64的使用
转载自:http://www.cnblogs.com/arix04/archive/2009/10/15/1511839.html AES加解密算法,使用Base64做转码以及辅助加密: packag ...
- Java实现AES加密解密
之前常用两种加密算法:Base64和Md5,前者容易破解,后者不可逆. AES采用对称加密方式,破解难度非常大,在可逆的基础上,能很好的保证数据的安全性. 这里介绍Java中实现AES加密算法的加密与 ...
- C#, Java, PHP, Python和Javascript几种语言的AES加密解密实现[转载]
原文:http://outofmemory.cn/code-snippet/35524/AES-with-javascript-java-csharp-python-or-php c#里面的AES加密 ...
- 前端AES加密解密
最开始使用的aes-js的npm包,后来发现npm上面那个包只能加密16个长度的字节,非16个长度的字符串就会报错,后来使用的是crypto-js, AES总共有四种加密方式,我们使用的CBC方式: ...
- AES加密解密——AES在JavaWeb项目中前台JS加密,后台Java解密的使用
一:前言 在软件开发中,经常要对数据进行传输,数据在传输的过程中可能被拦截,被监听,所以在传输数据的时候使用数据的原始内容进行传输的话,安全隐患是非常大的.因此就要对需要传输的数据进行在客户端进行加密 ...
随机推荐
- 数据结构之栈(Java,C语言的实现)以及相关习题巩固
目录 栈 概念以及代码实现 例题 232. 用栈实现队列 1614. 括号的最大嵌套深度 234. 回文链表 1614. 括号的最大嵌套深度 LCR 123. 图书整理 I 206. 反转链表 402 ...
- .NET 8 IApplicationBuilder详解
在上节中我们已经得知 WebApplication 实现了 IApplicationBuilder,我们浅谈了其pipe特质和构建方法,本节中将深入了解 ApplicationBuilder 以窥探 ...
- 算法学习笔记(15): Trie(字典树)
Trie树 Trie(字典树)是一种用于实现字符串检索的多叉树. Trie的每一个节点都可以通过 c 转移到下一层的一个节点. 我们可以看作可以通过某个字符转移到下一个字符串状态,直到转移到最终态为止 ...
- for while 要求选慢速的,但是for不卡,while 跟 递归 这两个容易卡
for比while慢,但是for不卡,while跟递归容易卡 int index = 0; bool jump=flase: for( index;index==0;;)/*这个空分号算一个语句*/ ...
- Linux 提权-Capabilities
本文通过 Google 翻译 Capabilities – Linux Privilege Escalation - Juggernaut-Sec 这篇文章所产生,本人仅是对机器翻译中部分表达别扭的字 ...
- 前端使用 Konva 实现可视化设计器(16)- 旋转对齐、触摸板操作的优化
这一章解决两个缺陷,一是调整一些快捷键,使得 Mac 触摸板可以正常操作:二是修复一个 Issue,使得即使素材节点即使被旋转之后,也能正常触发磁贴对齐效果,有个小坑需要注意. 请大家动动小手,给我一 ...
- C#拾贝
C#拾贝 C#C#技巧C#进阶 不积跬步无以至千里,不积小流无以成江河 C#拾贝 一.Linq 1.以...开头 StartsWith Repeater1.DataSource=con.Users.W ...
- onreadystatechange 属性
onreadystatechange 属性是 XMLHttpRequest 对象的一个事件处理器,用于在 XMLHttpRequest 对象的 readyState 属性发生变化时触发.这个属性通常用 ...
- EIGRP总结
EIGRP 思科私有,2013年公开,其他厂商不支持,所以用得不是很多 几秒钟就能完成收敛 触发更新,只要网络不发生变化就不会发生更新 按需更新,只更新变化的部分 ...
- Linux 内核:设备驱动模型(6)设备资源管理
Linux 内核:设备驱动模型(6)设备资源管理 背景 不要总是用Linux 2.6的风格来写驱动代码了,也该与时俱进一下. 参考:http://www.wowotech.net/device_mod ...