zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    Kotlin 数据类与密封类
    Kotlin 扩展
    Kotlin 接口
    Kotlin 继承
    Kotlin 类和对象
    Kotlin 循环控制
    Kotlin 条件控制
    Kotlin 基础语法
    freemarker的简单入门程序
    json数据格式的简单案例
  • 原文地址:https://www.cnblogs.com/twodog/p/12136878.html
Copyright © 2011-2022 走看看