Вопрос по java – Длина ввода должна быть кратна 16 при расшифровке с использованием шифра

7

У меня есть программа сокета сервера и клиента, сервер отправляет зашифрованное сообщение клиенту, т.е. код на стороне сервера:

cipher2 = Cipher.getInstance("AES"); 
secretKeySpec = new SecretKeySpec(decryptedText, "AES");
cipher2.init(Cipher.ENCRYPT_MODE, secretKeySpec);
feedback = "Your answer is wrong".getBytes();
cipher2.doFinal(feedback);
dos.writeInt(feedback.length);
dos.write(feedback);

код на стороне клиента:

int result_len = 0;
result_len = din.readInt();            
byte[] result_Bytes = new byte[result_len];
din.readFully(result_Bytes);
cipher2 = Cipher.getInstance("AES");
cipher2.init(Cipher.DECRYPT_MODE, aesKey);             
byte[] encrypt = cipher2.doFinal(result_Bytes);

Исключение бросить вbyte[] encrypt = cipher2.doFinal(result_Bytes);

javax.crypto.IllegalBlockSizeException: Input length must be multiple of 16 when decrypting with padded cipher
    at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:750)
    at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:676)
    at com.sun.crypto.provider.AESCipher.engineDoFinal(AESCipher.java:313)
    at javax.crypto.Cipher.doFinal(Cipher.java:2086)

в чем проблема?

Является ли result_len кратным 16? Если нет, убедитесь, что это так, тогда result_Bytes должен быть правильной длины. Ewald

Ваш Ответ

4   ответа
-3

и работал, когда я запускаю его без сервера. Ошибка заключалась в том, что когда я получал параметр из URL-адреса, зашифрованный URL-адрес, имеющий символ плюс (+), автоматически менялся на пробел. Это может быть вашей проблемой, проверьте это один раз.     Вот моя логика шифрования и дешифрования с генератором ключей, если вы хотите, вы также можете использовать его.

public class Anything
{
    private static final String ALGO = "AES";
    //generate 128bit key
    private static final String keyStr = "Z8LSq0wWwB5v+6YJzurcP463H3F12iZh74fDj4S74oUH4EONkiKb2FmiWUbtFh97GG/c/lbDE47mvw6j94yXxKHOpoqu6zpLKMKPcOoSppcVWb2q34qENBJkudXUh4MWcreondLmLL2UyydtFKuU9Sa5VgY/CzGaVGJABK2ZR94=";

    private static Key generateKey() throws Exception {
        byte[] keyValue = keyStr.getBytes("UTF-8");
        MessageDigest sha = MessageDigest.getInstance("SHA-1");
        keyValue = sha.digest(keyValue);
        keyValue = Arrays.copyOf(keyValue, 16); // use only first 128 bit       
        Key key = new SecretKeySpec(keyValue, ALGO);
        return key;
    }

    public static String encrypt(String Data) throws Exception {
            Key key = generateKey();
            Cipher c = Cipher.getInstance(ALGO);
            c.init(Cipher.ENCRYPT_MODE, key);
            byte[] encVal = c.doFinal(Data.getBytes());
            String encryptedValue = DatatypeConverter.printBase64Binary(encVal);
            return encryptedValue;
    }

    public static String decrypt(String encryptedData) throws Exception {
        Key key = generateKey();
        Cipher c = Cipher.getInstance(ALGO);
        c.init(Cipher.DECRYPT_MODE, key);       
        byte[] decordedValue = DatatypeConverter.parseBase64Binary(encryptedData);
        byte[] decValue = c.doFinal(decordedValue);
        String decryptedValue = new String(decValue);
        return decryptedValue;
    }
}
7

и она может варьироваться для разных случаев использования.

Scenario 1
Вы пытаетесь дешифровать значение, которое изначально не было правильно закодировано.

byte[] encryptedBytes = Base64.decodeBase64(encryptedBase64String);

Если строка по какой-либо причине неверно сконфигурирована или неправильно закодирована, вы увидите ошибку & quot; Длина ввода должна быть кратна 16 при расшифровке с использованием шифра с добавлением & quot;

Scenario 2
Теперь, если по какой-либо причине вы используете эту закодированную строку в URL (пытаясь передать значение base64Encoded в URL, это не удастся. Вы должны сделать URLEncoding и затем передать токен, он будет работать.

Scenario 3
При интеграции с одним из поставщиков мы обнаружили, что нам нужно было выполнить шифрование Base64 с помощью URLEncoder, но тогда нам не нужно декодировать его, потому что это было сделано внутри Продавцом.

2

что это сообщение устарело и было очень давно, но у меня тоже были проблемы с с точно такой же ошибкой:

проблема, с которой я столкнулся, связана с тем, что зашифрованный текст был преобразован в строку иbyte[] при попытке расшифровать его.

    private Key getAesKey() throws Exception {
    return new SecretKeySpec(Arrays.copyOf(key.getBytes("UTF-8"), 16), "AES");
}

private Cipher getMutual() throws Exception {
    Cipher cipher = Cipher.getInstance("AES");
    return cipher;// cipher.doFinal(pass.getBytes());
}

public byte[] getEncryptedPass(String pass) throws Exception {
    Cipher cipher = getMutual();
    cipher.init(Cipher.ENCRYPT_MODE, getAesKey());
    byte[] encrypted = cipher.doFinal(pass.getBytes("UTF-8"));
    return encrypted;

}

public String getDecryptedPass(byte[] encrypted) throws Exception {
    Cipher cipher = getMutual();
    cipher.init(Cipher.DECRYPT_MODE, getAesKey());
    String realPass = new String(cipher.doFinal(encrypted));
    return realPass;
}
Error: User Rate Limit Exceeded
Error: User Rate Limit Exceeded

Похожие вопросы