Я пытаюсь расшифровать текст, зашифрованный с помощью nodejs. Проще говоря, я пытаюсь зашифровать данные со стороны сервера и расшифровать их на стороне клиента при каждом вызове API.
Вот мой код на стороне сервера.
function encrpt(text) {
const seckey = '12345678123456781234567812345678';
var aesDec = crypto.createCipheriv("aes-256-ecb", seckey , '');
var output = aesDec.update(text, 'utf8', 'hex');
output += aesDec.final('hex');
return output;
}
Это код, который я использую для расшифровки на стороне клиента, он находится в Kotlin.
fun String.test() {
val skc = SecretKeySpec("12345678123456781234567812345678".toByteArray(Charsets.UTF_8), "AES")
val cipher = Cipher.getInstance("AES/ECB/PKCS5Padding")
cipher.init(Cipher.DECRYPT_MODE, skc)
val result = cipher.doFinal(this.toByteArray())
println(result.toString())
}
Но при этом я получаю javax.crypto.BadPaddingException: error:1e000065:Cipher functions:OPENSSL_internal:BAD_DECRYPT
в android studio.