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