【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解密的使用
一:前言 在软件开发中,经常要对数据进行传输,数据在传输的过程中可能被拦截,被监听,所以在传输数据的时候使用数据的原始内容进行传输的话,安全隐患是非常大的.因此就要对需要传输的数据进行在客户端进行加密 ...
随机推荐
- 事件对象的属性 div点击移动事件
// 事件对象的相关属性 // e.target 触发事件的标签对象 // e.target支持所有标签对象的操作 // ...
- kettle从入门到精通 第六十三课 ETL之kettle kettle调用python脚本的两种方法
kettle中不能直接调用python脚本,可以通过shell脚本和http进行调用pyton服务. 一.shell脚本调用python脚本 1.下面是一段简单的无参python脚本 import o ...
- INFINI Labs 产品更新 | Easysearch 新增快照搜索功能,Console 支持 OpenSearch 存储
INFINI Labs 产品又更新啦~,包括 Easysearch v1.7.0.Console v1.13.0.本次各产品更新了 Easysearch 快照搜索功能:Console 支持 OpenS ...
- Vue TypeScript 实战:掌握静态类型编程
title: Vue TypeScript 实战:掌握静态类型编程 date: 2024/6/10 updated: 2024/6/10 excerpt: 这篇文章介绍了如何在TypeScript环境 ...
- 微信支付普通商户与AppID账号关联管理-授权
微信支付普通商户与AppID账号关联管理 二.名词解释 名词 释义 微信支付普通商户 公司企业.政府机关.事业单位.社会组织.个体工商户.个人卖家.小微商户.(微信支付商户接入指引) AppID 已通 ...
- 新浪微博动态 RSA 分析图文+登录
Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` 新浪微博动态 RSA 分析图文+登录 日期:2016-10 ...
- QMS质量管理系统:打造企业质量控制的新纪元
在当今竞争激烈的市场环境下,产品质量是决定企业生存与发展的关键因素之一.为了确保从设计到交付的每一步都符合最高标准,一套高效.全面的质量管理系统(Quality Management System, ...
- php+sql后台实现从主表迁出至副表(数据超万条)
上万条甚至上百万数据进行迁出做备份或者进行不妨碍原系统数据的操作,现在很多企业都会用到,目前就需要将上百万条数据进行迁出到副表保存并操作,直接再后台写一个按钮进行操作,既方便操作也不会很慢.毕竟是客户 ...
- 自定义U盘图标
有没有想过你可以自定义U盘的图标 我才不想用这么Low的图标: 我的图标是这样的: 不好意思,本人叫郭飞,嘻嘻... 下面给出教程: 1.U盘里新建文件autorun.inf,并用记事本打开进行编辑 ...
- Linux安全审计之audit安装与使用
场景 安全最重要的一步是内部安全,如何监控用户的行为是一个永恒不变的话题. audit可以详细监控用户的行为,详细到查看或修改了某个文件.这些都可以在日志中查看到. 安装 小贴士: CentOS默认已 ...