package ;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import org.apache.commons.net.util.Base64;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @version V1.0
* @desc AES 加密工具類
*/
public class AESUtil {
private static Logger logger = LoggerFactory.getLogger(AESUtil.class);
private static final String KEY_ALGORITHM = "AES";
private static final String DEFAULT_CIPHER_ALGORITHM = "AES/ECB/PKCS5Padding";//默認(rèn)的加密算法
//自己定義初始密碼
private static final String password = "123456";
/**
* AES 加密操作
*
* @param content 待加密內(nèi)容
* @param password 加密密碼
* @return 返回Base64轉(zhuǎn)碼后的加密數(shù)據(jù)
*/
public static String encrypt(String content) {
try {
Cipher cipher = Cipher.getInstance(DEFAULT_CIPHER_ALGORITHM);// 創(chuàng)建密碼器
byte[] byteContent = content.getBytes("utf-8");
cipher.init(Cipher.ENCRYPT_MODE, getSecretKey(password));// 初始化為加密模式的密碼器
byte[] result = cipher.doFinal(byteContent);// 加密
return Base64.encodeBase64String(result);//
} catch (Exception ex) {
logger.error("加密內(nèi)容{}出現(xiàn)錯(cuò)誤:", content, ex);
}
return null;
}
/**
* AES 解密操作
*
* @param content
* @param password
* @return
*/
public static String decrypt(String content) {
try {
//實(shí)例化
Cipher cipher = Cipher.getInstance(DEFAULT_CIPHER_ALGORITHM);
//使用密鑰初始化喷众,設(shè)置為解密模式
cipher.init(Cipher.DECRYPT_MODE, getSecretKey(password));
//執(zhí)行操作
byte[] result = cipher.doFinal(Base64.decodeBase64(content));
return new String(result, "utf-8");
} catch (Exception ex) {
logger.error("解密內(nèi)容{}出現(xiàn)錯(cuò)誤:", content, ex);
}
return null;
}
/**
* 生成加密秘鑰
*
* @return
*/
private static SecretKeySpec getSecretKey(final String password) {
//返回生成指定算法密鑰生成器的 KeyGenerator 對(duì)象
KeyGenerator kg = null;
try
SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
secureRandom.setSeed(password.getBytes());
kg = KeyGenerator.getInstance(KEY_ALGORITHM);
//AES 要求密鑰長度為 128
kg.init(128, secureRandom);
//生成一個(gè)密鑰
SecretKey secretKey = kg.generateKey();
return new SecretKeySpec(secretKey.getEncoded(), KEY_ALGORITHM);// 轉(zhuǎn)換為AES專用密鑰
} catch (NoSuchAlgorithmException ex) {
logger.error("生成加密密鑰出現(xiàn)錯(cuò)誤出現(xiàn)錯(cuò)誤:", ex);
}
return null;
}
public static void main(String[] args) {
String s = "hello,您44444444444444444444444444444444好";
System.out.println("s:" + s);
String s1 = AESUtil.encrypt(s);
System.out.println("s1:" + s1);
System.out.println("s2:"+AESUtil.decrypt(s1));
}
}
AES實(shí)現(xiàn) 對(duì)稱雙向加密工具類
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
- 文/潘曉璐 我一進(jìn)店門沐兰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蔽挠,你說我怎么就攤上這事住闯。” “怎么了澳淑?”我有些...
- 文/不壞的土叔 我叫張陵比原,是天一觀的道長。 經(jīng)常有香客問我杠巡,道長量窘,這世上最難降的妖魔是什么? 我笑而不...
- 正文 為了忘掉前任氢拥,我火速辦了婚禮蚌铜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘嫩海。我一直安慰自己冬殃,他們只是感情好,可當(dāng)我...
- 文/花漫 我一把揭開白布叁怪。 她就那樣靜靜地躺著审葬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奕谭。 梳的紋絲不亂的頭發(fā)上耳璧,一...
- 文/蒼蘭香墨 我猛地睜開眼栖榨,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼昆汹!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起婴栽,我...
- 序言:老撾萬榮一對(duì)情侶失蹤满粗,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后愚争,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體映皆,經(jīng)...
- 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
- 正文 我和宋清朗相戀三年轰枝,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了捅彻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
- 正文 年R本政府宣布,位于F島的核電站寿烟,受9級(jí)特大地震影響澈驼,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜韧衣,卻給世界環(huán)境...
- 文/蒙蒙 一盅藻、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧畅铭,春花似錦氏淑、人聲如沸。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至炉擅,卻和暖如春辉懒,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谍失。 一陣腳步聲響...
- 正文 我出身青樓颠印,卻偏偏與公主長得像纲岭,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子线罕,可洞房花燭夜當(dāng)晚...
推薦閱讀更多精彩內(nèi)容
- 前言: 在我們開發(fā)中免不了和服務(wù)器做一些數(shù)據(jù)交互止潮,在交互過程中走得都是http請(qǐng)求,這類請(qǐng)求不像https那樣的安...
- 本文主要是前面《java實(shí)現(xiàn)雙向RSA + AES加密》的補(bǔ)充钞楼,只補(bǔ)充新增的代碼喇闸, JDK中自帶了橢圓曲線的簽名,...
- 加密工具類,提供RSA & AES & DES 等加密解密方法 github項(xiàng)目地址https://github....
- github項(xiàng)目地址 https://github.com/XHTeng/XHCryptorTools 工具類介...
- 在看公司的項(xiàng)目代碼的時(shí)候,注意到公司在請(qǐng)求數(shù)據(jù)夯秃,獲取數(shù)據(jù)的時(shí)候座咆,客戶端都做了加密和解密,因?yàn)橹安]有在實(shí)際開發(fā)中...