> 백엔드 개발 > Golang > My Go와 Pycrypto AES-CFB 암호화 결과가 다른 이유는 무엇입니까?

My Go와 Pycrypto AES-CFB 암호화 결과가 다른 이유는 무엇입니까?

DDD
풀어 주다: 2024-12-10 21:11:23
원래의
263명이 탐색했습니다.

Why Do My Go and Pycrypto AES-CFB Encryption Results Differ?

Go와 Pycrypto 간의 AES-CFB 암호화 결과 불일치

새로운 Go 애플리케이션을 기존 Python 코드베이스와 통합하려는 시도에서, 사용자는 두 언어로 생성된 암호문에서 불일치를 발견합니다. 이러한 차이는 특히 AES-CFB 암호화 구현에서 발생합니다.

이 문제는 각 언어에서 사용되는 CFB 세그먼트 크기의 차이로 인해 발생합니다. Pycrypto는 8비트(CFB8)의 세그먼트 크기를 사용하는 반면 Go는 이 구성에 대한 기본 지원을 제공하지 않습니다. 결과적으로 Go와 Pycrypto에서 생성된 암호문이 다르기 때문에 상호 해독이 불가능합니다.

Go 코드를 조사한 결과 CFBDecrypter 및 CFBEncrypter 클래스는 기본 소스 코드를 수정하여 잠재적으로 CFB8을 지원하도록 조정될 수 있는 것으로 나타났습니다. 이 접근 방식을 사용하면 Go 애플리케이션이 Pycrypto의 CFB8 설정을 사용하여 암호화된 암호문을 원활하게 해독할 수 있습니다.

수정된 Go 코드:

package main

import (
    "fmt"
    "crypto/cipher"
    "crypto/aes"
    "encoding/hex"
)

// encrypt
func main() {
    payload, err1 := hex.DecodeString("abababababababababababababababababababababababababababababababab")
    password, err2 := hex.DecodeString("0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF")
    iv, err3 := hex.DecodeString("00000000000000000000000000000000")

    if err1 != nil {
        fmt.Printf("error 1: %v", err1)
        return
    }

    if err2 != nil {
        fmt.Printf("error 2: %v", err2)
        return
    }

    if err3 != nil {
        fmt.Printf("error 3: %v", err3)
        return
    }

    aesBlock, err4 := aes.NewCipher(password)
    cfb8Decrypter := cipher.NewCFB8Decrypter(aesBlock, iv)
    cfb8Decrypter.XORKeyStream(payload, payload)

    fmt.Printf("%v\n", hex.EncodeToString(payload)) // should output dbf6b1877ba903330cb9cf0c4f530d40bf77fe2bf505820e993741c7f698ad6b
}
로그인 후 복사

결론:

Go의 CFBDecrypter를 적용하여 CFB8을 지원하는 CFBEncrypter 클래스를 통해 사용자는 Go 애플리케이션이 Pycrypto의 AES-CFB8 설정을 사용하여 암호화된 암호문을 효과적으로 해독할 수 있도록 하여 두 언어 간의 격차를 해소하고 Go 애플리케이션과 기존 Python 코드베이스 간의 원활한 통합을 허용할 수 있습니다.

위 내용은 My Go와 Pycrypto AES-CFB 암호화 결과가 다른 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿