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加密解密的更多相关文章

  1. java使用AES加密解密 AES-128-ECB加密

    java使用AES加密解密 AES-128-ECB加密 import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; impo ...

  2. php与java通用AES加密解密算法

    AES指高级加密标准(Advanced Encryption Standard),是当前最流行的一种密码算法,在web应用开发,特别是对外提供接口时经常会用到,下面是我整理的一套php与java通用的 ...

  3. [Java 实现AES加密解密]

    今天同学请教我这个问题,被坑了次…… 实现的功能是2个Java类:一个读取源文件生成加密文件,另一个类读取加密文件来解密. 整个过程其实很简单,java有AES的工具包,设好秘钥,设好输入内容,就得到 ...

  4. 使用java进行 AES 加密 解密?

    百度百科是这样定义的: 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标 ...

  5. Java使用AES加密解密

    AES加密机制: 密码学中的高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准. 这个标准用来替代原先的 ...

  6. 【java】AES加密解密|及Base64的使用

    转载自:http://www.cnblogs.com/arix04/archive/2009/10/15/1511839.html AES加解密算法,使用Base64做转码以及辅助加密: packag ...

  7. Java实现AES加密解密

    之前常用两种加密算法:Base64和Md5,前者容易破解,后者不可逆. AES采用对称加密方式,破解难度非常大,在可逆的基础上,能很好的保证数据的安全性. 这里介绍Java中实现AES加密算法的加密与 ...

  8. C#, Java, PHP, Python和Javascript几种语言的AES加密解密实现[转载]

    原文:http://outofmemory.cn/code-snippet/35524/AES-with-javascript-java-csharp-python-or-php c#里面的AES加密 ...

  9. 前端AES加密解密

    最开始使用的aes-js的npm包,后来发现npm上面那个包只能加密16个长度的字节,非16个长度的字符串就会报错,后来使用的是crypto-js, AES总共有四种加密方式,我们使用的CBC方式: ...

  10. AES加密解密——AES在JavaWeb项目中前台JS加密,后台Java解密的使用

    一:前言 在软件开发中,经常要对数据进行传输,数据在传输的过程中可能被拦截,被监听,所以在传输数据的时候使用数据的原始内容进行传输的话,安全隐患是非常大的.因此就要对需要传输的数据进行在客户端进行加密 ...

随机推荐

  1. node写接受

    选择数据库类型:mongodb 定义用户集合的字段(域): 用户名  密码  性别  爱好(多选)  简介 npm i -S express mongoose 在项目中连接mongodb服务 inde ...

  2. INFINI Labs 产品更新 | 发布 Easysearch Java 客户端,Console 支持 SQL 查询等功能

    近年来,日志管理平台越来越流行.使用日志管理平台可以实时地.统一地.方便地管理和查看日志,挖掘日志数据价值,驱动运维.运营,提升服务管理效率. 方案架构 Beats 是轻量级采集器,包括 Filebe ...

  3. centos7 添加极点五笔

    打开终端,输入: yum install ibus ibus-table-wubi 遇到"Is this OK",输入y回车. 完成后重启电脑. 打开"应用程序" ...

  4. CSDN 大规模抓取 GitHub 上的项目到 GitCode,伪造开发者主页引公愤

    事件起因 CSDN旗下的GitCode最近因为一种极其不道德的行为引起了开发者的广泛愤怒和抗议.CSDN在没有通知或征求开发者同意的情况下,悄悄地将大量GitHub上的开源项目搬运到了其自己的GitC ...

  5. LaravelLumen 分组求和问题 where groupBy sum

    在Laravel中使用分组求和,如果直接使用Laravel各数据库操作方法,应该会得出来如下代码式: DB::table('table_a') ->where('a','=',1) ->g ...

  6. TI AM62x工业核心板规格书(单/双/四核ARM Cortex-A53 + 单核ARM Cortex-M4F,主频1.4GHz)

    1 核心板简介 创龙科技SOM-TL62x是一款基于TI Sitara系列AM62x单/双/四核ARM Cortex-A53 + 单核ARM Cortex-M4F异构多核处理器设计的高性能低功耗工业级 ...

  7. python 转换PDF 到 EPS

    from win32com.client.dynamic import ERRORS_BAD_CONTEXT as ebc from win32com.client import DispatchEx ...

  8. ubuntu20 python2 通过安装包安装mysql-python

    前言 众里寻他千百度,蓦然回首,那人却在灯火阑珊处. 最近要测试一个python2环境的代码,其中用到了MySQLdb, 查询网络,发现要安装mysql-python,于是就进行了一番艰难的探索,现在 ...

  9. Express手稿

  10. 阿里云Centos7 安装mysql5.7 报错:./mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory

    在阿里云服务器Centos7中安装mysql5.7,解压数据库初始化后,报错 ./mysqld: error while loading shared libraries: libaio.so.1: ...