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 和 Pycrypto AES-CFB 加密結果不一樣?的詳細內容。更多資訊請關注PHP中文網其他相關文章!