JAVA中AES的加解密实现

密码学中的高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。

 

AES的基本要求是,采用对称分组密码体制,密钥长度的最少支持为128、192、256,分组长度128位,算法应易于各种硬件和软件实现。1998年NIST开始AES第一轮分析、测试和征集,共产生了15个候选算法。1999年3月完成了第二轮AES2的分析、测试。2000年10月2日美国政府正式宣布选中比利时密码学家Joan Daemen 和 Vincent Rijmen 提出的一种密码算法RIJNDAEL 作为 AES.   在应用方面,尽管DES在安全上是脆弱的,但由于快速DES芯片的大量生产,使得DES仍能暂时继续使用,为提高安全强度,通常使用独立密钥的三级DES。但是DES迟早要被AES代替。流密码体制较之分组密码在理论上成熟且安全,但未被列入下一代加密标准。   

AES加密数据块和密钥长度可以是128比特、192比特、256比特中的任意一个。

AES加密有很多轮的重复和变换。大致步骤如下:

1、密钥扩展(KeyExpansion),

2、初始轮(Initial Round),

3、重复轮(Rounds),每一轮又包括:SubBytes、ShiftRows、MixColumns、AddRoundKey,

4、最终轮(Final Round),最终轮没有MixColumns。

这里不具体讨论AES算法的实现原理,只对java的代码实现进行示例



创建密钥

/**生成key,作为加密和解密密钥且只有密钥相同解密加密才会成功
	 * @return
	 */
	public static Key createKey() {

		try {
			// 生成key
			KeyGenerator keyGenerator;
			//构造密钥生成器,指定为AES算法,不区分大小写
			keyGenerator = KeyGenerator.getInstance("AES");
			//生成一个128位的随机源,根据传入的字节数组
			keyGenerator.init(128);
			//产生原始对称密钥
			SecretKey secretKey = keyGenerator.generateKey();
			//获得原始对称密钥的字节数组
			byte[] keyBytes = secretKey.getEncoded();
			// key转换,根据字节数组生成AES密钥
			Key key = new SecretKeySpec(keyBytes, "AES");
			return key;
		} catch (NoSuchAlgorithmException e) {
			e.printStackTrace();
			return null;
		}

	}


加密过程


/**加密
	 * @param context 需要加密的明文
	 * @param key 加密用密钥
	 * @return
	 */
	public static byte[] jdkAES(String context, Key key) {
		try {

			Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
			
			cipher.init(cipher.ENCRYPT_MODE, key);
			//将加密并编码后的内容解码成字节数组
			byte[] result = cipher.doFinal(context.getBytes());

			System.out.println("jdk aes:" + Base64.encode(result));

			return result;

		} catch (NoSuchAlgorithmException | NoSuchPaddingException | InvalidKeyException | IllegalBlockSizeException
				| BadPaddingException e) {
			e.printStackTrace();
			return null;
		}
	}

Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");

上图出示的即是getInstance方法的参数意义, 用于返回实现指定转换的 Cipher 对象。


解密过程


	/** 解密
	 * @param result 加密后的密文byte数组
	 * @param key 解密用密钥
	 */
	public static void decrypt(byte[] result, Key key) {
		
		Cipher cipher;
		try {
			
			cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
			//初始化密码器,第一个参数为加密(Encrypt_mode)或者解密(Decrypt_mode)操作,第二个参数为使用的KEY
			cipher.init(Cipher.DECRYPT_MODE, key);
			result = cipher.doFinal(result);

		} catch (NoSuchAlgorithmException e) {
			e.printStackTrace();
		} catch (NoSuchPaddingException e) {
			e.printStackTrace();
		} catch (InvalidKeyException e) {
			e.printStackTrace();
		} catch (IllegalBlockSizeException e) {
			e.printStackTrace();
		} catch (BadPaddingException e) {
			e.printStackTrace();
		}

		System.out.println("jdk aes desrypt:" + new String(result));
	}


  • 5
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值