Java使用AES加解密
目录
1.1生成密钥
1.2密钥的存储
1.3获取存储的密钥
1.4加解密
1.5使用存储的密钥进行加解密示例
AES是一种对称的加密算法,可基于相同的密钥进行加密和解密。Java采用AES算法进行加解密的逻辑大致如下:
1、生成/获取密钥
2、加/解密
1.1生成密钥
密钥的生成是通过KeyGenerator来生成的。通过获取一个KeyGenerator实例,然后调用其generateKey()方法即可生成一个SecretKey对象。大致逻辑一般如下:
- private SecretKey geneKey() throws Exception {
- //获取一个密钥生成器实例
- KeyGenerator keyGenerator = KeyGenerator.getInstance(ALGORITHM);
- SecureRandom random = new SecureRandom();
- random.setSeed("123456".getBytes());//设置加密用的种子,密钥
- keyGenerator.init(random);
- SecretKey secretKey = keyGenerator.generateKey();
- return secretKey;
- }
上述生成密钥的过程中指定了固定的种子,每次生成出来的密钥都是一样的。还有一种形式,我们可以通过不指定SecureRandom对象的种子,即不调用其setSeed方法,这样每次生成出来的密钥都可能是不一样的。
- private SecretKey geneKey() throws Exception {
- //获取一个密钥生成器实例
- KeyGenerator keyGenerator = KeyGenerator.getInstance(ALGORITHM);
- SecureRandom random = new SecureRandom();
- keyGenerator.init(random);
- SecretKey secretKey = keyGenerator.generateKey();
- return secretKey;
- }
通过KeyGenerator的init(keySize)方法进行初始化,而不是通过传递SecureRandom对象进行初始化也可以达到上面的效果,每次生成的密钥都可能是不一样的。但是对应的keySize的指定一定要正确,AES算法的keySize是128。
- private SecretKey geneKey() throws Exception {
- //获取一个密钥生成器实例
- KeyGenerator keyGenerator = KeyGenerator.getInstance(ALGORITHM);
- keyGenerator.init(128);
- SecretKey secretKey = keyGenerator.generateKey();