0

我正在尝试解密使用 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_DECRYPTandroid studio。

4

1 回答 1

-1

你可以这样使用:

init{
   cipher = Cipher.getInstance("AES/CBC/PKCS5Padding")
   secretKeySpec = SecretKeySpec(secret.toByteArray(Charsets.UTF_8),"AES")
    }


fun decrypt(cipheredText: String?): String? {

            val array: ByteArray = Base64.decode(cipheredText, Base64.DEFAULT)
            val encrypted: ByteArray = array.copyOfRange(0, array.size)
            cipher!!.init(
                Cipher.DECRYPT_MODE,
                secretKeySpec,
                IvParameterSpec(iv.toByteArray())
            )
            return String(cipher!!.doFinal(encrypted)).trim()
        }

注意:iv 必须是 16 字节(128 位)

于 2020-03-11T09:30:30.457 回答