AES加密算法在Linux下出现随机加密结果

本文解决了AES加密在Windows和Linux环境下产生不同结果的问题。通过调整SecureRandom的初始化方式,确保了加密密钥的一致性。
特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过。如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处: http://www.cnblogs.com/mao2080/

1、问题描述

  项目当中用到了AES对数据进行加密,在windows环境下测试都正常,但是部署到linux服务器上之后产生的数据就是随机的。同事找了好半天没找出来,后面我决定撸起袖子从代码着手排查,阅读代码之后发现并没有异样,如何就问百老师,得到了一篇相关的blog。

2、解决方法

修改前代码:

1 KeyGenerator kgen = KeyGenerator.getInstance("AES");
2 kgen.init(128, new SecureRandom(password.getBytes()));
3 SecretKey secretKey = kgen.generateKey();

修改后代码:

1 KeyGenerator kgen = KeyGenerator.getInstance("AES");
2 SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");  
3 secureRandom.setSeed(password.getBytes());                      
4 kgen.init(128, secureRandom);
5 SecretKey secretKey = kgen.generateKey();

3、setSeed的作用?

待续

4、参考网站

https://blog.youkuaiyun.com/liuyan4794/article/details/8526440

转载于:https://www.cnblogs.com/mao2080/p/9040875.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值