package com.common.util; import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; public class AESUtil { /** * 解密 * * @param content 密文 * @param key 加密密碼 * @return String * @throws Exception 異常 */ public static String decode(String content, String key) throws Exception { byte[] arr = string2ByteArr(content); byte[] raw = key.getBytes("utf-8"); SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES"); Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding"); cipher.init(Cipher.DECRYPT_MODE, skeySpec); byte[] original = cipher.doFinal(arr); return new String(original,"utf-8"); } /** * 加密 * * @param content 原文 * @param key 加密密碼 * @return String * @throws Exception 異常 */ public static String encode(String content, String key) throws Exception { byte[] raw = key.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(content.getBytes("utf-8")); return byteArrToString(encrypted); } /** * 將字節數組轉換爲16進制字符串 * @param bcd 字節數組 * @return String */ public static String byteArrToString(byte[] bcd) { StringBuffer s = new StringBuffer(bcd.length * 2); for (int i = 0; i < bcd.length; i++) { s.append(bcdLookup[(bcd[i] >>> 4) & 0x0f]); s.append(bcdLookup[bcd[i] & 0x0f]); } return s.toString(); } /** * 將16進制字符串轉換爲字節數組 * @param str 16進制字符串 * @return byte[] */ public static byte[] string2ByteArr(String str) { byte[] bytes; bytes = new byte[str.length() / 2]; for (int i = 0; i < bytes.length; i++) { bytes[i] = (byte) Integer.parseInt(str.substring(2 * i, 2 * i + 2),16); } return bytes; } }