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实现相关推荐

  1. AES加密解密(java、web、app)

    AES加密解密(java.web.app) AES加密解密(java.web.app) java端 Web端 ios端 AES加密解密(java.web.app) java端 package com. ...

  2. DES加密解密算法Java实现

    DES 使用一个 56 位的密钥以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小.这是一个迭代的分组密码,使用称为 Feistel 的技术,其中将加密的文本块分成两半.使用子密钥对其中一半应 ...

  3. AES加密解密算法的C代码实现

     AES 加密解密的原理我就不说了, 弟兄们自己上百度去查, 文章很多. 我这里只列出从网上获取的代码的实现, 我修改了一些, 可以很方便的使用到你的代码里面. AES 比DES算法的强度更强.A ...

  4. MySQl数据库使用AES加密解密配Java代码使用

    MySQl数据库加密解密 待加密字段varchar INSERT INTO base_info(id,school_db_host) VALUES('1111254',HEX(AES_ENCRYPT( ...

  5. c++实现AES加密解密算法

    本文讲解c++实现AES加密解密功能,主要包含两部分: 实现AES加密解密功能的静态库 实现调用静态库的测试文件 本文代码是在win10系统,VS2013下调试. 一.AES加解密静态库 创建静态库工 ...

  6. php aes解密中文,PHP AES加密解密算法

    //--------第四种AES加密/解密方案 CBC模式,128-bit-------- /* * 实现AES加密 * $str : 要加密的字符串 * $keys : 加密密钥 * $iv : 加 ...

  7. AES加密解密算法设计(C++)

    目 录 1. 背景与意义 4 2. 系统设计 5 2.1系统主要目标 5 2.2主要软件需求(运行环境) 5 2.3功能模块与系统结构 6 3 系统功能程序设计 8 3.1基本要求部分 8 3.1.1 ...

  8. java aes128加密解密_java AES 128 位加密解密算法

    最近在做app后台的服务器,使用到AES加密解密算法,无奈网上的都不符合要求,于是自己借鉴着写了一个AES加密解密工具. 密钥长度问题 默认 Java 中仅支持 128 位密钥,当使用 256 位密钥 ...

  9. aes加密算法python语言实现_C#, Java, PHP, Python和Javascript几种语言的AES加密解密实现[转载]...

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

最新文章

  1. 漫画 | 上班第一天,前端把后端告上县衙,还列了 5 宗罪!
  2. NETMerger - DotNet 组件(dll或exe)合并
  3. IT运维管理方案 成就企业信息化建设
  4. SBO用户清理(最近一直未登录过用户)
  5. SharePoint 使用脚本为表单绑定事件
  6. superset 图标调整
  7. s3cmd安装及使用
  8. RMQ算法,求区间最值
  9. 安装deepin_deepin使用笔记,安装steam客户端
  10. 联想开机启动项按哪个_win7系统如何修改系统启动项 win7系统修改系统启动项方法【步骤】...
  11. Unity3d中使用百度语音识别及语音合成【含源码】
  12. 《算法导论》(第3版)第4章练习答案
  13. 纳多德通过ISO 9001质量、ISO 14001环境、ISO 45001职业健康安全国际管理体系认证
  14. 还不知道IEEE、ACM、SCI、EI、nature、期刊、会议论文之间的关系?一幅关系图搞定~
  15. java-等差等比求和
  16. ice的意思_ice是什么意思_ice的翻译_音标_读音_用法_例句_爱词霸在线词典
  17. 基于SpringBoot监控Java项目,暴漏springboot内置端点
  18. 局域网arp攻击_什么是arp攻击?arp攻击的解决方法有哪些?
  19. 接口测试系列之--前端交互测试和后端逻辑测试
  20. 软件需求管理用例方法 pdf_双全科技|管家婆管理库存必备“序列号”,管家婆软件的使用方法...

热门文章

  1. mysql 怎么查询结果补0_mysql查询连续时间数据——无数据补0
  2. eve模拟器华为镜像_EVE-NG简单入门介绍
  3. 复杂存储过程学习_对象存储在无人驾驶高精度地图的场景实践
  4. 使用netsh命令来管理IP安全策略(详细介绍)
  5. 重学前端学习笔记(三十六)--Flex 布局
  6. .NET Core2.1下采用EFCore比较原生IOC、AspectCore、AutoFac之间的性能
  7. Scrapy爬取妹子图保存到不同目录下
  8. Struts(七):action配置文件之通配符映射
  9. 【转】常见浏览器兼容性问题与解决方案css篇
  10. Android 设置thumb图片大小