博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JAVA-AES加密的使用
阅读量:6616 次
发布时间:2019-06-25

本文共 3182 字,大约阅读时间需要 10 分钟。

  hot3.png

需要说明的是,AES加密需要保存对称密钥。对称密钥通常保存在服务器上的不同数据库中,以保证数据的安全性。在数据库中获取密钥通常通过id获取。

AES加密动画演示:

 

AES密码学中的高级加密标准(Advanced Encryption Standard,AES),又称  高级加密标准 

Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准。2006年,高级加密标准已然成为对称密钥加密中最流行的算法之一。   该算法为比利时密码学家Joan Daemen和Vincent Rijmen所设计,结合两位作者的名字,以Rijndael之命名之,投稿高级加密标准的甄选流程。(Rijdael的发音近于 "Rhinedoll"。) 

 

import java.security.InvalidKeyException;  import java.security.NoSuchAlgorithmException;  import java.security.Security;    import javax.crypto.BadPaddingException;  import javax.crypto.Cipher;  import javax.crypto.IllegalBlockSizeException;  import javax.crypto.KeyGenerator;  import javax.crypto.NoSuchPaddingException;  import javax.crypto.SecretKey;    public class EncrypAES {            //KeyGenerator 提供对称密钥生成器的功能,支持各种算法      private KeyGenerator keygen;      //SecretKey 负责保存对称密钥      private SecretKey deskey;      //Cipher负责完成加密或解密工作      private Cipher c;      //该字节数组负责保存加密的结果      private byte[] cipherByte;            public EncrypAES() throws NoSuchAlgorithmException, NoSuchPaddingException{          Security.addProvider(new com.sun.crypto.provider.SunJCE());          //实例化支持DES算法的密钥生成器(算法名称命名需按规定,否则抛出异常)          keygen = KeyGenerator.getInstance("AES");          //生成密钥          deskey = keygen.generateKey();          //生成Cipher对象,指定其支持的DES算法          c = Cipher.getInstance("AES");      }            /**      * 对字符串加密      *       * @param str      * @return      * @throws InvalidKeyException      * @throws IllegalBlockSizeException      * @throws BadPaddingException      */      public byte[] Encrytor(String str) throws InvalidKeyException,              IllegalBlockSizeException, BadPaddingException {          // 根据密钥,对Cipher对象进行初始化,ENCRYPT_MODE表示加密模式          c.init(Cipher.ENCRYPT_MODE, deskey);          byte[] src = str.getBytes();          // 加密,结果保存进cipherByte          cipherByte = c.doFinal(src);          return cipherByte;      }        /**      * 对字符串解密      *       * @param buff      * @return      * @throws InvalidKeyException      * @throws IllegalBlockSizeException      * @throws BadPaddingException      */      public byte[] Decryptor(byte[] buff) throws InvalidKeyException,              IllegalBlockSizeException, BadPaddingException {          // 根据密钥,对Cipher对象进行初始化,DECRYPT_MODE表示加密模式          c.init(Cipher.DECRYPT_MODE, deskey);          cipherByte = c.doFinal(buff);          return cipherByte;      }        /**      * @param args      * @throws NoSuchPaddingException       * @throws NoSuchAlgorithmException       * @throws BadPaddingException       * @throws IllegalBlockSizeException       * @throws InvalidKeyException       */      public static void main(String[] args) throws Exception {          EncrypAES de1 = new EncrypAES();          String msg ="郭XX-搞笑相声全集";          byte[] encontent = de1.Encrytor(msg);          byte[] decontent = de1.Decryptor(encontent);          System.out.println("明文是:" + msg);          System.out.println("加密后:" + new String(encontent));          System.out.println("解密后:" + new String(decontent));      }    }

 

转载于:https://my.oschina.net/qkmc/blog/856696

你可能感兴趣的文章
sed的基本用法
查看>>
ansible模块批量管理
查看>>
细说浏览器特性检测(1)-jQuery1.4添加部分
查看>>
积跬步,聚小流------Bootstrap学习记录(1)
查看>>
Android官方架构组件LiveData: 观察者模式领域二三事
查看>>
vmware workstation14永久激活密钥分享
查看>>
Myeclipse中打开接口实现类的快捷键
查看>>
使用JdbcTemplate和JdbcDaoSupport
查看>>
Glibc 和 uClibc
查看>>
Mysql学习第三课-分析二进制日志进行增量备份和还原
查看>>
HDU 6073 - Matching In Multiplication | 2017 Multi-University Training Contest 4
查看>>
如何检测域名是否被微信屏蔽 微信域名检测接口API是如何实现
查看>>
POJ1611-The Suspects
查看>>
Linux下安装Python-3.3.2【转】
查看>>
LeetCode OJ:Merge Two Sorted Lists(合并两个链表)
查看>>
功能测试
查看>>
【BZOJ 1901】Dynamic Rankings
查看>>
Github-Client(ANDROID)开源之旅(二) ------ 浅析ActionBarSherkLock
查看>>
React-Native 之 GD (十六)首页筛选功能
查看>>
SSISDB5:使用TSQL脚本执行Package
查看>>