为什么我的 Go 和 Pycrypto AES-CFB 加密结果不同?
Dec 10, 2024 pm 09:11 PMGo 和 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 |
|
结论:
通过改编Go的CFBDecrypter和CFBEncrypter通过添加支持 CFB8 的类,用户可以确保 Go 应用程序能够有效解密使用 Pycrypto 的 AES-CFB8 设置加密的密文,从而弥合两种语言之间的差距,并允许 Go 应用程序与现有 Python 代码库之间的无缝集成。
以上是为什么我的 Go 和 Pycrypto AES-CFB 加密结果不同?的详细内容。更多信息请关注PHP中文网其他相关文章!

热门文章

热门文章

热门文章标签

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)