猿问

Python AES-CTR 与 Golang 不兼容

我在 Ubuntu 16.04 上使用 Python2.7 和 pycryptodome 3.6.6 和 Golang1.10.4。


我选择的加密算法是 AES-CTR-128。但是用Python和Golang加密的数据结果是不一样的。因此,这两种语言编写的应用程序之间的通信存在问题。


这是我的工具:


Python:


#coding=utf-8


from __future__ import absolute_import

import binascii

from Crypto.Cipher import AES

from Crypto.Util import Counter


def hexlify(binary):

    return binascii.hexlify(binary)


class AES_CTR(object):

    def __init__(self, key, iv):

        assert len(key) == 16

        assert len(iv) == 16

        ctr = Counter.new(128)

        self.aes = AES.new(key, AES.MODE_CTR, counter=ctr)


    def encrypt(self, plain_data):

        return self.aes.encrypt(plain_data)


    def decrypt(self, encrypted_data):

        return self.aes.decrypt(encrypted_data)


if __name__ == '__main__':

    aes = AES_CTR('abcdef0123456789', '0123456789abcdef')

    print hexlify(aes.encrypt("hello")) #print '9b1a038478'

    print hexlify(aes.encrypt("hello")) #print '8751ea0448'

    print hexlify(aes.encrypt("world")) #print 'b6aa7c286b'

戈朗


package main


import (

    "crypto/aes"

    "crypto/cipher"

    "encoding/hex"

    "fmt"

)



type AESCipher struct {

    iv []byte

    stream cipher.Stream

}


func NewAESCipher(key []byte, iv []byte) *AESCipher {

    if (len(iv) != 16 || len(key) != 16) {

        panic("iv length or key length error")

    }

    block, err := aes.NewCipher(key)

    if (err != nil) {

        panic(err)

    }

    return &AESCipher {

        iv: iv,

        stream: cipher.NewCTR(block, iv),

    }

}


func (cipher *AESCipher) Encrypt(buffer []byte) []byte {

    encrypted := make([]byte, len(buffer))

    cipher.stream.XORKeyStream(encrypted, buffer)

    return encrypted

}


func (cipher *AESCipher) Decrypt(buffer []byte) []byte {

    decrypted := make([]byte, len(buffer))

    cipher.stream.XORKeyStream(decrypted, buffer)

    return decrypted

}


BIG阳
浏览 201回答 3
3回答

慕盖茨4494581

pycryptodome 的默认实现是不正确的。我们可以更改它Counter以使其按预期工作。ctr = Counter.new(128, initial_value=bytes_to_long(iv))现在它完美地工作。

呼啦一阵风

Counter您可以通过根本不使用该类来简化代码,此处记录如下:self.aes = AES.new(key, AES.MODE_CTR, initial_value=iv)

拉莫斯之舞

试试这个:ctr = Counter.new(128, initial_value= int.frombytes(iv.encode(),'little'))IV 始终作为整数值和字节格式的 Key 传递。从上述链接检查文档
随时随地看视频慕课网APP

相关分类

Go
我要回答