我几乎是加密的新手.
我正在尝试解密一个字节数组,当我提供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,但对我来说并不太有意义.
任何帮助将不胜感激.
非常感谢,
理查德.