欢迎来到代码驿站!

Linux

当前位置:首页 > 服务器 > Linux

完美解决Linux操作系统下aes解密失败的问题

时间:2021-08-19 09:47:53|栏目:Linux|点击:
现象描述:
windows上加解密正常,linux上加密正常,解密时发生如下异常:
复制代码 代码如下:

javax.crypto.BadPaddingException: Given final block not properly padded
       at com.sun.crypto.provider.SunJCE_f.b(DashoA13*..)
       at com.sun.crypto.provider.SunJCE_f.b(DashoA13*..)
       at com.sun.crypto.provider.AESCipher.engineDoFinal(DashoA13*..)
       at javax.crypto.Cipher.doFinal(DashoA13*..)
       at chb.test.crypto.AESUtils.crypt(AESUtils.java:386)
       at chb.test.crypto.AESUtils.AesDecrypt(AESUtils.java:254)
       at chb.test.crypto.AESUtils.main(AESUtils.java:40)

解决方法:
经过检查之后,定位在生成KEY的方法上,如下:
复制代码 代码如下:

public static SecretKey getKey (String strKey) {
         try {        
            KeyGenerator _generator = KeyGenerator.getInstance( "AES" );
            _generator.init(128, new SecureRandom(strKey.getBytes()));
                return _generator.generateKey();
        }  catch (Exception e) {
             throw new RuntimeException( " 初始化密钥出现异常 " );
        }
      }

修改到如下方式,问题解决:
复制代码 代码如下:

  public static SecretKey getKey(String strKey) {
         try {        
            KeyGenerator _generator = KeyGenerator.getInstance( "AES" );
             SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG" );
            secureRandom.setSeed(strKey.getBytes());
            _generator.init(128,secureRandom);
                return _generator.generateKey();
        }  catch (Exception e) {
             throw new RuntimeException( " 初始化密钥出现异常 " );
        }
      }

原因分析
SecureRandom 实现完全随操作系统本身的?炔孔刺?,除非调用方在调用 getInstance 方法之后又调用了 setSeed 方法;该实现在 windows 上每次生成的 key 都相同,但是在 solaris 或部分 linux 系统上则不同。

上一篇:再谈远程控制linux下

栏    目:Linux

下一篇:CentOS 7 下使用 iptables

本文标题:完美解决Linux操作系统下aes解密失败的问题

本文地址:http://www.codeinn.net/misctech/168062.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有