java – 解密错误:“no iv set when one expected”

我几乎是加密的新手.

我正在尝试解密一个字节数组,当我提供IV时,我得到一个例外:
InvalidAlgorithmParameterException(no iv set when one expected).

这是我的代码(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创建了一个适当的密钥.

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...