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

特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过。如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处: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.csdn.net/liuyan4794/article/details/8526440

原文地址:https://www.cnblogs.com/mao2080/p/9040875.html