使用Hutool进行AES加密不支持JDK1.6问题解决方案

首先介绍一下Hutool,借用其官网的一段话:

引用自Hutool官网
Hutool是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。
Hutool中的工具方法来自每个用户的精雕细琢,它涵盖了Java开发底层代码中的方方面面,它既是大型项目开发中解决小问题的利器,也是小型项目中的效率担当;
Hutool是项目中“util”包友好的替代,它节省了开发人员对项目中公用类和公用工具方法的封装时间,使开发专注于业务,同时可以最大限度的避免封装不完善带来的bug。

使用Hutool的jar包可比较方便的进行AES加密,但是目前Hutool的各版本最低支持jdk1.7,对于jdk1.6环境的程序就比较尴尬了,下面介绍一个替代方案。

使用Hutool的jar进行aes加密的代码为:

public static String encByAES(String data) {
		String key = "XXXXXXXXXXX";
		SymmetricCrypto aes = new SymmetricCrypto(SymmetricAlgorithm.AES, key.getBytes());
		byte[] strByte = aes.encrypt(data);
		return Base64.encode(strByte);
	}

这个方式在jdk1.8环境下没有问题,由于Hutool不支持jdk1.6,jdk1.6环境下程序想用aes加密采用如下方式:

public static String Encrypt(String sSrc) throws Exception {
		String sKey = "XXXXXXXX";
		
        byte[] raw = sKey.getBytes("utf-8");
        SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");//"算法/模式/补码方式"
        cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
        byte[] encrypted = cipher.doFinal(sSrc.getBytes("utf-8"));
        return new BASE64Encoder().encode(encrypted);//此处使用BASE64做转码功能,同时能起到2次加密的作用。
    }

第一次执行以上代码大概率会报如下错误:

这里是引用
Caused by: java.security.InvalidKeyException: Illegal key size or default parameters

报错原因为:美国限制 aes 256位 以上加密出口,于是Sun通过权限文件(local_policy.jar, US_export_policy.jar)做了相应限制。
Oracle在其官方网站上提供了无政策限制权限文件(Unlimited Strength Jurisdiction Policy Files),只需要将其部署在JRE环境中,就可以解决限制问题。

jar包下载连接:
oracle官网版:
jce_policy-6.zip
csdn版:
https://download.csdn.net/download/u011497507/87270593

下载对应版本的jce包,解压并放到 jdk 文件夹下的 /jre6/lib/security 文件夹中即可,我的路径为:
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 您好!使用Hutool进行AES加密需要先引入Hutool和JDK17的依赖,可以在pom.xml中添加如下代码: ```xml <dependencies> <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.4.4</version> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-text</artifactId> <version>1.9</version> </dependency> <dependency> <groupId>org.bouncycastle</groupId> <artifactId>bcprov-jdk17</artifactId> <version>1.69</version> </dependency> </dependencies> ``` 然后可以使用HutoolAES工具类进行加密,示例代码如下: ```java import cn.hutool.crypto.SecureUtil; import cn.hutool.crypto.symmetric.AES; public class AesTest { public static void main(String[] args) { String content = "Hello, world!"; // 待加密内容 String password = "1234567890123456"; // 密钥,长度必须为16位 // 初始化AES加密AES aes = SecureUtil.aes(password.getBytes()); // 加密内容 byte[] encrypt = aes.encrypt(content.getBytes()); // 输出加密结果 System.out.println(new String(encrypt)); } } ``` 其中,密码必须是16位长度的字符串,可以根据实际需求进行修改。 ### 回答2: Hutool AES是一个Java工具库,用于提供AES加密算法的实现。AES(Advanced Encryption Standard),也称为高级加密标准,是一种对称加密算法,是目前应用最广泛的加密算法之一。 JDK 17是Java Development Kit的最新版本,也是Java编程语言的一个平台。它提供了许多功能和工具来简化开发过程,并提供了强大的安全性支持Hutool AES结合了JDK 17的加密功能,提供了一种简单易用的方式来实现AES加密。通过Hutool AES,我们可以使用Java代码来加密和解密数据。 对于使用Hutool AES进行加密,我们首先需要创建一个AES加密器。然后,我们可以使用加密器的方法来加密和解密数据。加密过程中,我们需要指定密钥和加密模式。Hutool AES还提供了对填充模式和初始向量的支持,以增强加密的安全性。 使用Hutool AES加密数据的一个常见的应用场景是在进行敏感数据传输时,例如用户的密码或银行账号等。通过使用AES加密算法,我们可以将数据加密后再传输,以保护数据的安全性。 综上所述,Hutool AES结合了JDK 17的加密功能,提供了一个简单易用的方式来实现AES加密使用Hutool AES,我们可以使用Java代码来加密和解密数据,以提高数据的安全性。 ### 回答3: Hutool是一个Java工具包,提供了一系列的工具类,包括加密解密工具类。其中,AES(Advanced Encryption Standard)是一种对称加密算法,它在加密和解密过程中使用相同的密钥。JDK 1.7是Java Development Kit的一个版本,是Java编程语言的一个开发平台。 Hutool中的AES加密功能可以在JDK 1.7环境中使用使用HutoolAES工具类,我们可以方便地对数据进行加密和解密操作。加密过程中,我们需要指定加密的内容和密钥,并可以选择加密模式、填充方式等。加密后的结果是一串密文,具有较高的安全性。解密过程中,我们需要指定解密的密文和密钥,然后使用相同的算法进行解密,得到原始的明文数据。 AES加密算法具有安全性强、可靠性高的特点,被广泛应用于网络通信、数据库存储等领域。通过使用HutoolAES加密功能,我们可以在JDK 1.7环境中方便地对数据进行保护,确保数据的安全性和机密性。 总之,Hutool提供的AES加密工具类可以在JDK 1.7环境中使用,帮助我们对数据进行加密和解密操作。这为我们提供了一个方便、高效的加密解密解决方案,保护了数据的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值