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

Posted 知行合一

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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

以上是关于AES加密算法在Linux下出现随机加密结果的主要内容,如果未能解决你的问题,请参考以下文章

IOS AES加密

加密算法在linux下相同输入每次加密结果都不同的问题

aes加密安全吗

aes加密在linux下会生成随机key的解决办法

AES-128-CBC加密过程中,我想随机产生16位的向量,希望各位能给我一下C语言代码的实现。

在 Android 和 iPhone 中使用 AES-128 加密(不同的结果)