java.security.InvalidKeyException: неправильный алгоритм: требуется DESede или TripleDES - PullRequest
1 голос
/ 11 марта 2019

Я написал этот код, мой ключ: "ooWqEPcw7KR / h / JIbrFCRHiEVaybvnB2".

    try
    {
        Base64Decoder base64Decoder=new Base64Decoder();

        String encryptType="DESede/ECB/PKCS5Padding";
        String workingKey="ooWqEPcw7KR/h/JIbrFCRHiEVaybvnB2";
        SecretKey secretKey=new SecretKeySpec(base64Decoder.decode(workingKey), encryptType);

        Cipher cipher=Cipher.getInstance(encryptType);
        cipher.init(1, secretKey);
    }
    catch(NoSuchAlgorithmException | NoSuchPaddingException | InvalidKeyException e)
    {
        e.printStackTrace();
    }

Но я получаю эту ошибку !!!

java.security.InvalidKeyException: Wrong algorithm: DESede or TripleDES required
    at com.sun.crypto.provider.DESedeCrypt.init(DESedeCrypt.java:65)
    at com.sun.crypto.provider.ElectronicCodeBook.init(ElectronicCodeBook.java:93)
    at com.sun.crypto.provider.CipherCore.init(CipherCore.java:582)
    at com.sun.crypto.provider.CipherCore.init(CipherCore.java:458)
    at  com.sun.crypto.provider.DESedeCipher.engineInit(DESedeCipher.java:166)
    at javax.crypto.Cipher.implInit(Cipher.java:802)
    at javax.crypto.Cipher.chooseProvider(Cipher.java:864)
    at javax.crypto.Cipher.init(Cipher.java:1249)
    at javax.crypto.Cipher.init(Cipher.java:1186)
    at EncryptText.main(EncryptText.java:24)

Ответы [ 2 ]

2 голосов
/ 11 марта 2019
Класс

DESedeCrypt поддерживает только алгоритмы DESede и TripleDES согласно исходному коду:

void init(boolean decrypting, String algorithm, byte[] keys)
        throws InvalidKeyException {
    if (!algorithm.equalsIgnoreCase("DESede")
                && !algorithm.equalsIgnoreCase("TripleDES")) {
        throw new InvalidKeyException
            ("Wrong algorithm: DESede or TripleDES required");
    }

Ваш код должен использовать один из двух в SecretKey. Cipher может оставаться как DESede/ECB/PKCS5Padding:

String workingKey = "ooWqEPcw7KR/h/JIbrFCRHiEVaybvnB2";
SecretKey secretKey = new SecretKeySpec(
        Base64.getDecoder().decode(workingKey), 
        "DESede");
Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");
cipher.init(1, secretKey);
1 голос
/ 11 марта 2019

Вы должны написать SecretKeySpec как

SecretKey secretKey=new SecretKeySpec(base64Decoder.decode(workingKey),"DESede");

Также используйте Cipher.ENCRYPT_MODE и Cipher.DECRYPT_MODE вместо констант.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...