首页 后端开发 Golang 为什么我的 Go 和 Pycrypto AES-CFB 加密结果不同?

为什么我的 Go 和 Pycrypto AES-CFB 加密结果不同?

Dec 10, 2024 pm 09:11 PM

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 代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

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和CFBEncrypter通过添加支持 CFB8 的类,用户可以确保 Go 应用程序能够有效解密使用 Pycrypto 的 AES-CFB8 设置加密的密文,从而弥合两种语言之间的差距,并允许 Go 应用程序与现有 Python 代码库之间的无缝集成。

以上是为什么我的 Go 和 Pycrypto AES-CFB 加密结果不同?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Go语言包导入:带下划线和不带下划线的区别是什么? Go语言包导入:带下划线和不带下划线的区别是什么? Mar 03, 2025 pm 05:17 PM

Go语言包导入:带下划线和不带下划线的区别是什么?

如何编写模拟对象和存根以进行测试? 如何编写模拟对象和存根以进行测试? Mar 10, 2025 pm 05:38 PM

如何编写模拟对象和存根以进行测试?

Beego框架中NewFlash()函数如何实现页面间短暂信息传递? Beego框架中NewFlash()函数如何实现页面间短暂信息传递? Mar 03, 2025 pm 05:22 PM

Beego框架中NewFlash()函数如何实现页面间短暂信息传递?

如何使用跟踪工具了解GO应用程序的执行流? 如何使用跟踪工具了解GO应用程序的执行流? Mar 10, 2025 pm 05:36 PM

如何使用跟踪工具了解GO应用程序的执行流?

您如何在GO中编写单元测试? 您如何在GO中编写单元测试? Mar 21, 2025 pm 06:34 PM

您如何在GO中编写单元测试?

Go语言中如何将MySQL查询结果List转换为自定义结构体切片? Go语言中如何将MySQL查询结果List转换为自定义结构体切片? Mar 03, 2025 pm 05:18 PM

Go语言中如何将MySQL查询结果List转换为自定义结构体切片?

如何定义GO中仿制药的自定义类型约束? 如何定义GO中仿制药的自定义类型约束? Mar 10, 2025 pm 03:20 PM

如何定义GO中仿制药的自定义类型约束?

Go语言如何便捷地写入文件? Go语言如何便捷地写入文件? Mar 03, 2025 pm 05:15 PM

Go语言如何便捷地写入文件?

See all articles