AES加密解密算法Java实现
生活随笔
收集整理的這篇文章主要介紹了
AES加密解密算法Java实现
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
AES加密算法是密碼學中的高級加密標準(Advanced Encryption Standard,AES),又稱Rijndael加密法,是美國聯邦政府采用的一種區塊加密標準。這個標準用來替代原先的DES,已經被多方分析且廣為全世界所使用。
AES 是一個新的可以用于保護電子數據的加密算法。明確地說,AES 是一個迭代的、對稱密鑰分組的密碼,它可以使用128、192 和 256 位密鑰,并且用 128 位(16字節)分組加密和解密數據。與公共密鑰密碼使用密鑰對不同,對稱密鑰密碼使用相同的密鑰加密和解密數據。通過分組密碼返回的加密數據 的位數與輸入數據相同。迭代加密使用一個循環結構,在該循環中重復置換(permutations )和替換(substitutions)輸入數據。
參考代碼如下:
package com.gddx.des;import java.security.Key; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator;public class AesUtil {private final static String AES = "AES";private final static String charset = "UTF-8";private final static String defKey = "gddxbdhp";//8字節key長度/**** 加密* @param plain* @param keySeed* @param charSet* @return 輸出密文 16進制*/public static String encrypt(String plain, String keySeed, String charSet) {try {byte[] byteContent = plain.getBytes(charSet);Cipher cipher = Cipher.getInstance(AES);cipher.init(Cipher.ENCRYPT_MODE, getKey(keySeed));byte[] buf = cipher.doFinal(byteContent);// byte[]轉16進制StringBuffer sb = new StringBuffer();for (int i = 0; i < buf.length; i++) {String hex = Integer.toHexString(buf[i] & 0xFF);if (hex.length() == 1) {hex = '0' + hex;}sb.append(hex.toUpperCase());}return sb.toString();} catch (Exception e) {e.printStackTrace();}return null;}/**** 解密 輸入16進制的字符串* * @param layer* @param keySeed* @param charSet* @return 原文*/public static String decrypt(String layer, String keySeed, String charSet) {try {byte[] byteContent = new byte[layer.length() / 2];if (layer.length() < 1) {return null;}// 將16進制轉換為二進制for (int i = 0; i < layer.length() / 2; i++) {int high = Integer.parseInt(layer.substring(i * 2, i * 2 + 1), 16);int low = Integer.parseInt(layer.substring(i * 2 + 1, i * 2 + 2), 16);byteContent[i] = (byte) (high * 16 + low);}Cipher cipher = Cipher.getInstance(AES);cipher.init(Cipher.DECRYPT_MODE, getKey(keySeed));byte[] buf = cipher.doFinal(byteContent);return new String(buf, charSet);} catch (Exception e) {e.printStackTrace();}return null;}public static Key getKey(String keySeed) {if (keySeed == null) {keySeed = System.getenv("AES_SYS_KEY");}if (keySeed == null) {keySeed = System.getProperty("AES_SYS_KEY");}if (keySeed == null || keySeed.trim().length() == 0) {keySeed = "abcd1234!@#$";// 默認種子}try {SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");secureRandom.setSeed(keySeed.getBytes());KeyGenerator generator = KeyGenerator.getInstance("AES");generator.init(secureRandom);return generator.generateKey();} catch (Exception e) {throw new RuntimeException(e);}}public static void main(String[] args) {String express="AES加密解密算法";long start=System.currentTimeMillis();String layer = AesUtil.encrypt(express,defKey,charset);long end =System.currentTimeMillis();System.out.println("加密時長:"+String.valueOf(end-start));System.out.println("密文:"+layer);String plain = AesUtil.decrypt(layer,defKey,charset);System.out.println("原文:"+plain);} }執行結果如下: 加密時長:358 密文:D21DE80BAFDDE82CC14EEE3F2D7DBC2E87C4230E49575DD1E97174F21E3A2D0A 原文:AES加密解密算法
實際上,我的需求是設計一個對稱可逆的加密解密算法,這個算法加密時間快生成的密文字節少,絕對的輕量而且安全。
總結
以上是生活随笔為你收集整理的AES加密解密算法Java实现的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: DES加密解密算法Java实现
- 下一篇: 【正一专栏】春日随感—赢在起跑线上