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 중국어 웹사이트의 기타 관련 기사를 참조하세요!