Błąd deszyfrowania: „no iv set kiedy oczekiwano”

Jestem prawie nowy w szyfrowaniu.

Próbuję odszyfrować tablicę bajtów, a gdy dostarczam IV, otrzymuję wyjątek: InvalidAlgorithmParameterException (nie ustawiono iv, gdy się go spodziewano).

Oto mój kod (iv to tablica 16 bajtów, która nie jest pusta i ma wartości używane podczas szyfrowania):

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, encriptionKey,new IvParameterSpec(iv));

Jeśli nie podam IV, szyfr zostanie zainicjowany ok:

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, encriptionKey);

Próbując znaleźć odpowiedź, znalazłem implementację JCEStreamCipher (tutaj) który może nie odpowiadać wersji, której używam, ale ma jakiś kod, który czyni mnie rzeczą, której nie rozumiem poprawnie.

Oto kod:

   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");
        }
    }

Wygląda na to, że nie mogę podać IV podczas deszyfrowania, ale nie ma to dla mnie zbyt dużego sensu.

wszelka pomoc zostanie bardzo doceniona.

wielkie dzięki, Richardzie.

questionAnswers(1)

yourAnswerToTheQuestion