Python to Kotlin AES通信(javax.crypto.BadPaddingException)

问题描述 投票:0回答:1

我试图在Python上用AES加密一个UTF-8字符串,并在Kotlin中解密,以下是Python加密部分。

class aes():

    def __init__(self, key):
        self.bs = AES.block_size
        self.key = hashlib.sha256(key.encode()).digest()

    def encrypt(self, raw):
        raw = self.pad(raw)
        iv = self.key[:self.bs]  # Random.new().read(self.bs)
        cipher = AES.new(self.key, AES.MODE_CBC, iv)
        return base64.b64encode(iv + cipher.encrypt(raw.encode()))

    def pad(self, s):
        return s + (self.bs - len(s) % self.bs) * chr(self.bs - len(s) % self.bs)

...

client_key = self.rsa.decrypt(int(connection.recv(bufsize).decode()))

enc = aes(client_key)
em = enc.encrypt("AES_OK")

connection.send(em+b'\0')

和Kotlin的解密部分。

object AES256 {
    private val decorder = Base64.getDecoder()
    private fun cipher(opmode:Int, secretKey:String):Cipher {

        val c = Cipher.getInstance("AES/CBC/PKCS7Padding")

        val sk = SecretKeySpec(secretKey.toByteArray(Charsets.UTF_8), "AES")
        val iv = IvParameterSpec(secretKey.substring(0, 16).toByteArray(Charsets.UTF_8))
        c.init(opmode, sk, iv)
        return c
    }
    @RequiresApi(Build.VERSION_CODES.O)
    fun decrypt(str:String, secretKey:String):String {
        val byteStr = decorder.decode(str.toByteArray(Charsets.UTF_8))
        // Error here
        return String(cipher(Cipher.DECRYPT_MODE, secretKey).doFinal(byteStr))
    }
}

fun readBytes(input: BufferedReader) : String {
    var byte: Int = input.read()
    var r = ""
    while(byte != 0) {
        r += byte.toChar()
        byte = input.read()
    }
    return r
}

resposta = readBytes(input)
resposta = AES256.decrypt(resposta, atc_aesk.toString(Charsets.UTF_8))

然后我得到了以下的异常:

javax.crypto.BadPaddingException: error:1e000065:Cipher functions:OPENSSL_internal:BAD_DECRYPT
  1. 所有的RSA和连接代码都能正常工作 两边的密文和密钥都是一样的。
  2. 我使用的是32字节的密钥,我也试过16字节的,同样的错误。

我将非常感谢任何帮助或输入,谢谢。

python kotlin encryption aes
1个回答
0
投票

用户总裁James K. Polk在评论中回答了这个问题,错误在于我只在Python代码中对密钥进行了哈希,而没有在Kotlin中... self.key = hashlib.sha256(key.encode()).digest()

我试着找了整整一个星期才找到问题,我真的觉得自己好笨,谢谢James K. Polk社长。

© www.soinside.com 2019 - 2024. All rights reserved.