java – 解密错误:“no iv set when one expected”
发布时间:2020-12-14 05:14:25 所属栏目:Java 来源:网络整理
导读:我几乎是加密的新手. 我正在尝试解密一个字节数组,当我提供IV时,我得到一个例外: InvalidAlgorithmParameterException(no iv set when one expected). 这是我的代码(iv是一个16字节的数组,不为空,并且具有加密时使用的值): Cipher cipher = Cipher.getInst
我几乎是加密的新手.
我正在尝试解密一个字节数组,当我提供IV时,我得到一个例外: 这是我的代码(iv是一个16字节的数组,不为空,并且具有加密时使用的值): Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); cipher.init(Cipher.DECRYPT_MODE,encriptionKey,new IvParameterSpec(iv)); 如果我没有指定IV,则密码将初始化好: Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); cipher.init(Cipher.DECRYPT_MODE,encriptionKey); 试图找到一个答案我确实发现一个JCEStreamCipher(here)的实现可能不对应于我使用的版本,但有一些代码,使我的东西我不能正确理解. 以下是代码: if ((ivLength != 0) && !(param instanceof ParametersWithIV)) { SecureRandom ivRandom = random; if (ivRandom == null) { ivRandom = new SecureRandom(); } if ((opmode == Cipher.ENCRYPT_MODE) || (opmode == Cipher.WRAP_MODE)) { byte[] iv = new byte[ivLength]; ivRandom.nextBytes(iv); param = new ParametersWithIV(param,iv); ivParam = (ParametersWithIV)param; } else { throw new InvalidAlgorithmParameterException("no IV set when one expected"); } } 看起来我解密时不能提供IV,但对我来说并不太有意义. 任何帮助将不胜感激. 非常感谢, 解决方法
解决了.
我使用的是错误的密钥,而不是AES可以创建的密钥. 以前我有 KeySpec spec = new PBEKeySpec(password.toCharArray(),encryptionKeySalt,12345,256); SecretKey encriptionKey = factory.generateSecret(spec); 这创建了一个JCEPBEKey. 我失踪了 Key encriptionKey = new SecretKeySpec(encriptionKey.getEncoded(),"AES"); 这为AES创建了一个适当的密钥. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |