600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > AES加密解密算法Java实现

AES加密解密算法Java实现

时间:2022-12-08 07:26:33

相关推荐

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加密解密算法

实际上,我的需求是设计一个对称可逆的加密解密算法,这个算法加密时间快生成的密文字节少,绝对的轻量而且安全。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。