`
234390216
  • 浏览: 10243213 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
博客专栏
A5ee55b9-a463-3d09-9c78-0c0cf33198cd
Oracle基础
浏览量:463070
Ad26f909-6440-35a9-b4e9-9aea825bd38e
springMVC介绍
浏览量:1776390
Ce363057-ae4d-3ee1-bb46-e7b51a722a4b
Mybatis简介
浏览量:1399156
Bdeb91ad-cf8a-3fe9-942a-3710073b4000
Spring整合JMS
浏览量:395242
5cbbde67-7cd5-313c-95c2-4185389601e7
Ehcache简介
浏览量:680295
Cc1c0708-ccc2-3d20-ba47-d40e04440682
Cas简介
浏览量:531354
51592fc3-854c-34f4-9eff-cb82d993ab3a
Spring Securi...
浏览量:1185788
23e1c30e-ef8c-3702-aa3c-e83277ffca91
Spring基础知识
浏览量:469487
4af1c81c-eb9d-365f-b759-07685a32156e
Spring Aop介绍
浏览量:151598
2f926891-9e7a-3ce2-a074-3acb2aaf2584
JAXB简介
浏览量:68470
社区版块
存档分类
最新评论

Java使用AES加解密

阅读更多

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();
		return secretKey;
	}

 

 

但是这种每次生成出来的密钥都是不同的情况下,我们需要把加密用的密钥存储起来,以供解密的时候使用,不然就没法进行解密了。

 

1.2密钥的存储

密钥SecretKey里面最核心的内容就是其中的密钥对应的字节数组,可以通过SecretKey的getEncoded()方法获取。然后把它存储起来即可。最简单的方式就是直接写入一个文件中。

		//把上面的密钥存起来
		Path keyPath = Paths.get("D:/aes.key");
		Files.write(keyPath, secretKey.getEncoded());

 

 

1.3获取存储的密钥

获取存储的密钥的核心是把密钥的字节数组转换为对应的SecretKey。这可以通过SecretKeySpec来获取,其实现了SecretKey接口,然后构造参数里面将接收密钥的字节数组。

	private SecretKey readKey(Path keyPath) throws Exception {
		//读取存起来的密钥
		byte[] keyBytes = Files.readAllBytes(keyPath);
		SecretKeySpec keySpec = new SecretKeySpec(keyBytes, ALGORITHM);
		return keySpec;
	}

 

 

1.4加解密

Java采用AES算法进行加解密的过程是类似的,具体如下:

1、指定算法,获取一个Cipher实例对象

Cipher cipher = Cipher.getInstance(ALGORITHM);//算法是AES

 

2、生成/读取用于加解密的密钥

SecretKey secretKey = this.geneKey();

 

3、用指定的密钥初始化Cipher对象,同时指定加解密模式,是加密模式还是解密模式。

cipher.init(Cipher.ENCRYPT_MODE, secretKey);

 

4、通过update指定需要加密的内容,不可多次调用。

cipher.update(content.getBytes());

 

5、通过Cipher的dofinal()进行最终的加解密操作。

byte[] result = cipher.doFinal();//加密后的字节数组

 

通过以上几步就完成了使用AES算法进行加解密的操作了。其实第4、5步是可以合在一起的,即在进行doFinal的时候传递需要进行加解密的内容。但是如果update指定了加密的内容,而doFinal的时候也指定了加密的内容,那最终加密出来的结果将是两次指定的加密内容的和对应的加密结果。

byte[] result = cipher.doFinal(content.getBytes());

 

以下是一次加解密操作的完整示例。

public class AESTest {

	private static final String ALGORITHM = "AES";
	
	/**
	 * 生成密钥
	 * @return
	 * @throws Exception
	 */
	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();
		//把上面的密钥存起来
		Path keyPath = Paths.get("D:/aes.key");
		Files.write(keyPath, secretKey.getEncoded());
		return secretKey;
	}
	
	/**
	 * 读取存储的密钥
	 * @param keyPath
	 * @return
	 * @throws Exception
	 */
	private SecretKey readKey(Path keyPath) throws Exception {
		//读取存起来的密钥
		byte[] keyBytes = Files.readAllBytes(keyPath);
		SecretKeySpec keySpec = new SecretKeySpec(keyBytes, ALGORITHM);
		return keySpec;
	}
	
	/**
	 * 加密测试
	 */
	@Test
	public void testEncrypt() throws Exception {
		//1、指定算法、获取Cipher对象
		Cipher cipher = Cipher.getInstance(ALGORITHM);//算法是AES
		//2、生成/读取用于加解密的密钥
		SecretKey secretKey = this.geneKey();
		//3、用指定的密钥初始化Cipher对象,指定是加密模式,还是解密模式
		cipher.init(Cipher.ENCRYPT_MODE, secretKey);
		String content = "Hello AES";//需要加密的内容
		//4、更新需要加密的内容
		cipher.update(content.getBytes());
		//5、进行最终的加解密操作
		byte[] result = cipher.doFinal();//加密后的字节数组
		//也可以把4、5步组合到一起,但是如果保留了4步,同时又是如下这样使用的话,加密的内容将是之前update传递的内容和doFinal传递的内容的和。
//		byte[] result = cipher.doFinal(content.getBytes());
		String base64Result = Base64.getEncoder().encodeToString(result);//对加密后的字节数组进行Base64编码
		System.out.println("Result: " + base64Result);
	}
	
	/**
	 * 解密测试
	 */
	@Test
	public void testDecrpyt() throws Exception {
		Cipher cipher = Cipher.getInstance(ALGORITHM);
		SecretKey secretKey = this.geneKey();
		cipher.init(Cipher.DECRYPT_MODE, secretKey);
		String content = "pK9Xw4zqTMXYraDadSGJE3x/ftrDxIg2AM/acq0uixA=";//经过Base64加密的待解密的内容
		byte[] encodedBytes = Base64.getDecoder().decode(content.getBytes());
		byte[] result = cipher.doFinal(encodedBytes);//对加密后的字节数组进行解密
		System.out.println("Result: " + new String(result));
	}
	
}

 

1.5使用存储的密钥进行加解密示例

	@Test
	public void test() throws Exception {
		Cipher cipher = Cipher.getInstance(ALGORITHM);
		KeyGenerator keyGenerator = KeyGenerator.getInstance(ALGORITHM);
		keyGenerator.init(128);
		SecretKey secretKey = keyGenerator.generateKey();
		//把上面的密钥存起来
		Path keyPath = Paths.get("D:/aes.key");
		Files.write(keyPath, secretKey.getEncoded());
		
		//读取存起来的密钥
		SecretKey key = this.readKey(keyPath);
		cipher.init(Cipher.ENCRYPT_MODE, key);
		cipher.update("Hello World".getBytes());
		//密文
		byte[] encryptBytes = cipher.doFinal();
		System.out.println(Base64.getEncoder().encodeToString(encryptBytes));
		
		//用取出来的密钥进行解密
		cipher.init(Cipher.DECRYPT_MODE, key);
		//明文
		byte[] decryptBytes = cipher.doFinal(encryptBytes);
		System.out.println(new String(decryptBytes));
	}

 

在上面的示例中,我们先生成了一个密钥,然后把它保存到本地文件中,然后再把它读出来,分别用以加密和解密。而且我们加密和解密都是用的同一个Cipher对象,但是在使用前需要重新通过init方法初始化加解密模式。

 

(Elim写于2017年4月20日星期四)

 

 

 

 

0
0
分享到:
评论

相关推荐

    java代码-java使用AES加密解密 AES-128-ECB加密

    java代码-java使用AES加密解密 AES-128-ECB加密 ——学习参考资料:仅用于个人学习使用

    c/c++与java互通 AES加密解密

    本话题主要探讨如何在C/C++和Java之间使用基本的字符串和数组操作实现AES加密解密,而不依赖任何额外的加密库。 首先,我们来了解AES加密的基本原理。AES基于块密码,每个数据块为128位,支持128、192和256位的密钥...

    delphi 和java的AES加密解密

    delphi7和java通用的AES加密和解密

    Java实现AES加密和解密算法

    在Java中实现AES(Advanced Encryption Standard)加密和解密算法主要涉及到对称密钥加密技术。AES算法是一种块密码,采用固定大小的128位(16字节)块进行加密和解密,支持128、192和256位的密钥长度。在给定的代码...

    java 实现aes加解密算法

    本篇文章将详细介绍如何在Java中实现AES加解密,帮助你理解并掌握这一核心技术。 AES算法是在DES(Data Encryption Standard)的基础上发展起来的,具有更高的安全性,支持128位、192位和256位的密钥长度,而默认的...

    java的AES加密解密

    在Java中,我们可以使用`javax.crypto`包中的类来实现AES加密解密。主要涉及以下类: 1. `Cipher`: 用于加密和解密数据的核心类,提供多种加密算法支持。 2. `KeyGenerator`: 用于生成密钥的类,根据指定的算法生成...

    Delphi.rar_AES_AES加密_delphi AES加密_delphi 加解密_java delphi aes

    本资源"Delphi.rar_AES_AES加密_delphi AES加密_delphi 加解密_java delphi aes"提供的是在Delphi编程环境中实现AES加密和解密的示例代码,其目标是与Java平台上的加解密过程保持兼容。 首先,让我们深入了解一下...

    Delphi与Java互通AES加解密算法.zip

    本资源"Delphi与Java互通AES加解密算法.zip"正专注于解决这一问题,提供了一套适用于Delphi和Java环境的AES(Advanced Encryption Standard)加解密算法,确保在两种语言之间进行安全的数据传输。 AES,即高级加密...

    DelphiXE10.3与Java互通AES加解密算法,亲测可用.zip

    DelphiXE10.3与Java互通AES加解密算法,亲测可用。支持ECB、CBC算法,支持128、192、256密匙长度,支持密匙和向量设置,支持补码方式PKCS5和PKCS7,支持16进制密文和Base64密文。

    JAVA实现AES加密和解密

    本文将详细介绍如何使用Java实现AES的加密和解密过程,特别是针对16位长度的秘钥,并解决加解密过程中可能出现的乱码问题。 首先,AES加密算法有多种工作模式,如ECB(Electronic Codebook)、CBC(Cipher Block ...

    c/c++ 与java互通 AES加密解密,算法ECB

    压缩包里有两个工程,一个vc6.0一个myeclipse,本帖是修复贴,原帖地址c/c++ 与java互通 AES加密解密,算法ECB/PKCS5PADDING http://download.csdn.net/download/wangsonghiweed/4328267 -来自CSDN,有童鞋反映有...

    java使用Hex编码解码实现Aes加密解密功能示例

    在AES加密过程中,通常需要一个密钥(key)来对数据进行加解密。在这个示例中,密钥首先是以字符串形式存在,然后通过`Hex.decodeHex()`方法将其从Hex编码转换回原始的字节数组,这是因为AES算法需要字节形式的密钥...

    java后台及前端js使用AES互相加解密及前端md5加密

    在Java中,可以使用`javax.crypto.Cipher`类和`java.security.SecureRandom`类来实现AES加解密。前端JavaScript也有相应的库,如CryptoJS,可以用于AES操作。 2. **Java后台AES加解密**:在Java中,首先需要创建一...

    Java解决AES加密解密 ( AES/ECB/PKCS5Padding )

    JAVA解决AES ECB 模式下加密解密;附加国内三方AES加密网站---http://tool.chacuo.net/cryptaes;如有用解决您工作问题,烦请点个赞

    Java AES128加密解密

    在Java中实现AES128加密解密,通常会使用Java Cryptography Extension (JCE) 提供的API。AES支持三种工作模式:ECB(Electronic Codebook)、CBC(Cipher Block Chaining)和CFB(Cipher Feedback)。其中,ECB是最...

    JAVA实现AES加密解密工具类

    总之,AES加密解密工具类在Java中实现涉及对Cipher类的熟练使用,理解加密模式和填充策略,以及正确管理和生成密钥和初始化向量。这个工具类使得开发者能够方便地在项目中集成加密功能,保障数据的安全。

    java使用AES加密/解密文件

    本教程将详细讲解如何在Java中使用AES加密和解密文件,以确保数据的安全性。 AES全称为Advanced Encryption Standard,是一种对称加密算法,它在信息安全领域中被广泛应用,因为其速度快、效率高且安全性强。Java...

    Java使用AES加密和解密的实例详解

    下面将详细讲解Java采用AES算法进行加解密的逻辑。 密钥生成是通过KeyGenerator来生成的。通过获取一个KeyGenerator实例,然后调用其generateKey()方法即可生成一个SecretKey对象。密钥的生成可以指定固定的种子,...

    前后端AES加解密信息交互示例(后端JAVA)

    本示例"前后端AES加解密信息交互示例(后端JAVA)"提供了一个详细的教程,演示了如何利用AES加密技术来确保在前端与后端之间传递的数据安全无虞。AES,即高级加密标准(Advanced Encryption Standard),是一种广泛...

Global site tag (gtag.js) - Google Analytics