Android Kotlin AES Decryption возвращает Bad Decryption - PullRequest
0 голосов
/ 22 марта 2019

У меня в настоящее время есть проблема с расшифровкой моего файла.Проблема уже держит меня в течение нескольких дней.Каждая попытка заканчивается исключением BAD_DECRYPT.Вот как выглядит расшифрованный код.

val factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA256")
        val spec = PBEKeySpec(Constant().SECRET_KEY.toCharArray(), Constant().SALT_KEY.toByteArray(Charset.defaultCharset()), 65536, 256)
        val tmp = factory.generateSecret(spec)
        val secret = SecretKeySpec(tmp.encoded, "AES")
        val ivKeyBytes = Constant().IV_SECRET_KEY.toByteArray()
        val finalIvs = ByteArray(16)
        val len = if (ivKeyBytes.count() > 16) 16 else ivKeyBytes.count()
        System.arraycopy(ivKeyBytes, 0, finalIvs, 0, len)
        val ivps = IvParameterSpec(finalIvs)

        val cipher = Cipher.getInstance("AES/CBC/PKCS5Padding")
        cipher.init(Cipher.DECRYPT_MODE, secret, ivps)
        return cipher.doFinal(fileData)

Шифрование происходит через задачу на моем сервере с openssl, это выглядит так

openssl enc -aes-256-cbc -md md5 -in PATH_TO_MY_FILE -out PATH_TO_MY_ENC_FILE -S "MYSALT_IN_HEX" -iv "MY_IV_IN_HEX" -k MY_KEY_PASS

Что я делаю неправильно?Кто-нибудь может мне помочь?

Заранее спасибо Себастьян

1 Ответ

0 голосов
/ 23 марта 2019

Алгоритм для SecretKeyFactory не выглядит правильным. Вы используете openssl без флага pbkdf2 и с хэшем md5. Я думаю, что соответствующий алгоритм будет "PBEWITHMD5AND256BITAES-CBC-OPENSSL" от поставщика надувных замков.

Вам также необходимо извлечь зашифрованный текст из файла - он начинается со строки Salted__, за которой следует соль, а затем зашифрованный текст.

С этими изменениями у меня отлично работает расшифровка:

    Security.addProvider(BouncyCastleProvider())
    val factory = SecretKeyFactory.getInstance("PBEWITHMD5AND256BITAES-CBC-OPENSSL", "BC")
    val salt = Arrays.copyOfRange(fileData, 8, 16)
    val spec = PBEKeySpec(Constant().SECRET_KEY.toCharArray(), salt, 65536, 256)
    ...
    val ct = Arrays.copyOfRange(fileData, 16, fileData.size)
    return cipher.doFinal(ct)
...