mirror of
				https://gitee.com/dromara/hutool.git
				synced 2025-10-25 10:19:23 +08:00 
			
		
		
		
	add test and change AES costructor
This commit is contained in:
		| @@ -8,6 +8,7 @@ import cn.hutool.crypto.Padding; | ||||
|  | ||||
| import javax.crypto.SecretKey; | ||||
| import javax.crypto.spec.IvParameterSpec; | ||||
| import java.security.spec.AlgorithmParameterSpec; | ||||
|  | ||||
| /** | ||||
|  * AES加密算法实现<br> | ||||
| @@ -121,14 +122,14 @@ public class AES extends SymmetricCrypto { | ||||
| 	/** | ||||
| 	 * 构造 | ||||
| 	 * | ||||
| 	 * @param mode    模式{@link Mode} | ||||
| 	 * @param padding {@link Padding}补码方式 | ||||
| 	 * @param key     密钥,支持三种密钥长度:128、192、256位 | ||||
| 	 * @param iv      偏移向量,加盐 | ||||
| 	 * @param mode       模式{@link Mode} | ||||
| 	 * @param padding    {@link Padding}补码方式 | ||||
| 	 * @param key        密钥,支持三种密钥长度:128、192、256位 | ||||
| 	 * @param paramsSpec 算法参数,例如加盐等 | ||||
| 	 * @since 3.3.0 | ||||
| 	 */ | ||||
| 	public AES(Mode mode, Padding padding, SecretKey key, IvParameterSpec iv) { | ||||
| 		this(mode.name(), padding.name(), key, iv); | ||||
| 	public AES(Mode mode, Padding padding, SecretKey key, AlgorithmParameterSpec paramsSpec) { | ||||
| 		this(mode.name(), padding.name(), key, paramsSpec); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -180,13 +181,13 @@ public class AES extends SymmetricCrypto { | ||||
| 	/** | ||||
| 	 * 构造 | ||||
| 	 * | ||||
| 	 * @param mode    模式 | ||||
| 	 * @param padding 补码方式 | ||||
| 	 * @param key     密钥,支持三种密钥长度:128、192、256位 | ||||
| 	 * @param iv      加盐 | ||||
| 	 * @param mode       模式 | ||||
| 	 * @param padding    补码方式 | ||||
| 	 * @param key        密钥,支持三种密钥长度:128、192、256位 | ||||
| 	 * @param paramsSpec 算法参数,例如加盐等 | ||||
| 	 */ | ||||
| 	public AES(String mode, String padding, SecretKey key, IvParameterSpec iv) { | ||||
| 		super(StrUtil.format("AES/{}/{}", mode, padding), key, iv); | ||||
| 	public AES(String mode, String padding, SecretKey key, AlgorithmParameterSpec paramsSpec) { | ||||
| 		super(StrUtil.format("AES/{}/{}", mode, padding), key, paramsSpec); | ||||
| 	} | ||||
| 	//------------------------------------------------------------------------- Constrctor end | ||||
| } | ||||
|   | ||||
| @@ -7,10 +7,14 @@ import cn.hutool.crypto.KeyUtil; | ||||
| import cn.hutool.crypto.Mode; | ||||
| import cn.hutool.crypto.Padding; | ||||
| import cn.hutool.crypto.symmetric.AES; | ||||
| import org.bouncycastle.crypto.util.BasicAlphabetMapper; | ||||
| import org.bouncycastle.jcajce.spec.FPEParameterSpec; | ||||
| import org.junit.Assert; | ||||
| import org.junit.Test; | ||||
|  | ||||
| import javax.crypto.SecretKey; | ||||
| import javax.crypto.spec.GCMParameterSpec; | ||||
| import javax.crypto.spec.SecretKeySpec; | ||||
| import java.security.SecureRandom; | ||||
|  | ||||
| public class AESTest { | ||||
| @@ -112,4 +116,51 @@ public class AESTest { | ||||
| 		final String decryptStr = aes.decryptStr(result1); | ||||
| 		Assert.assertEquals(content, decryptStr); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 见:https://github.com/dromara/hutool/issues/1814 | ||||
| 	 */ | ||||
| 	@Test | ||||
| 	public void fpeTest() { | ||||
| 		// 映射字符表,规定了明文和密文的字符范围 | ||||
| 		BasicAlphabetMapper numberMapper = new BasicAlphabetMapper("0123456789"); | ||||
|  | ||||
| 		// 初始化 aes 密钥 | ||||
| 		byte[] keyBytes = RandomUtil.randomBytes(16); | ||||
|  | ||||
| 		AES aes = new AES("FF1", "NoPadding", | ||||
| 				new SecretKeySpec(keyBytes, "FF1"), | ||||
| 				new FPEParameterSpec(numberMapper.getRadix(), new byte[]{})); | ||||
|  | ||||
| 		// 原始数据 | ||||
| 		String phone = "13534534567"; | ||||
| 		// 加密 | ||||
| 		byte[] inputDataByte = numberMapper.convertToIndexes(phone.toCharArray()); | ||||
| 		byte[] encrypt = aes.encrypt(inputDataByte); | ||||
|  | ||||
| 		// 通过 mapper 将密文输出处理为原始格式 | ||||
| 		char[] encryptChars = numberMapper.convertToChars(encrypt); | ||||
| 		// 手机号码加密: 13534534567 -> 49725950626 | ||||
| 		Assert.assertEquals(phone.length(), encryptChars.length); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 见:https://blog.csdn.net/weixin_42468911/article/details/114358682 | ||||
| 	 */ | ||||
| 	@Test | ||||
| 	public void gcmTest() { | ||||
| 		final SecretKey key = KeyUtil.generateKey("AES"); | ||||
| 		byte[] iv = RandomUtil.randomBytes(12); | ||||
|  | ||||
| 		AES aes = new AES("GCM", "NoPadding", | ||||
| 				key, | ||||
| 				new GCMParameterSpec(128, iv)); | ||||
|  | ||||
| 		// 原始数据 | ||||
| 		String phone = "13534534567"; | ||||
| 		// 加密 | ||||
| 		byte[] encrypt = aes.encrypt(phone); | ||||
| 		final String decryptStr = aes.decryptStr(encrypt); | ||||
| 		Assert.assertEquals(phone, decryptStr); | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,38 @@ | ||||
| package cn.hutool.crypto.test.symmetric; | ||||
|  | ||||
| import cn.hutool.core.util.CharsetUtil; | ||||
| import cn.hutool.core.util.RandomUtil; | ||||
| import cn.hutool.crypto.KeyUtil; | ||||
| import cn.hutool.crypto.symmetric.SymmetricCrypto; | ||||
| import org.junit.Assert; | ||||
| import org.junit.Test; | ||||
|  | ||||
| import javax.crypto.spec.IvParameterSpec; | ||||
|  | ||||
| /** | ||||
|  * 见:https://stackoverflow.com/questions/32672241/using-bouncycastles-chacha-for-file-encryption | ||||
|  */ | ||||
| public class ChaCha20Test { | ||||
|  | ||||
| 	@Test | ||||
| 	public void encryptAndDecryptTest() { | ||||
| 		String content = "test中文"; | ||||
|  | ||||
| 		// 32 for 256 bit key or 16 for 128 bit | ||||
| 		byte[] key = RandomUtil.randomBytes(32); | ||||
| 		// 64 bit IV required by ChaCha20 | ||||
| 		byte[] iv = RandomUtil.randomBytes(12); | ||||
|  | ||||
| 		final SymmetricCrypto chacha = new SymmetricCrypto("ChaCha20", | ||||
| 				KeyUtil.generateKey("ChaCha", key), | ||||
| 				new IvParameterSpec(iv) | ||||
| 		); | ||||
|  | ||||
| 		// 加密为16进制表示 | ||||
| 		String encryptHex = chacha.encryptHex(content); | ||||
| 		// 解密为字符串 | ||||
| 		String decryptStr = chacha.decryptStr(encryptHex, CharsetUtil.CHARSET_UTF_8); | ||||
|  | ||||
| 		Assert.assertEquals(content, decryptStr); | ||||
| 	} | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Looly
					Looly