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

}


蓝山帝景
浏览 284回答 3
3回答
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python