首頁 > 後端開發 > Golang > 為什麼我的 Go 和 Pycrypto AES-CFB 加密結果不一樣?

為什麼我的 Go 和 Pycrypto AES-CFB 加密結果不一樣?

DDD
發布: 2024-12-10 21:11:23
原創
262 人瀏覽過

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

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板