【发布时间】:2014-04-09 17:30:47
【问题描述】:
我在 Python 中有以下代码运行良好。它使用 mcrypt 模块解密变量 encrypted_data 中的数据。我想在 Ruby 中执行相同的操作。因此我需要 openssl 模块。不幸的是,Ruby 版本不起作用。这是错误:
`final': bad decrypt (OpenSSL::Cipher::CipherError)
编辑 我创建了一个 GitHub 存储库供您测试。在此处下载源代码:github.com/ph3nx/ruby-decrypt
编辑 2
bad decrypt 错误不再出现。我通过设置d.padding = 0 解决了这个问题。问题是:解密后的数据仍然不正确。我看不到图片。
如果您需要有关我的系统或其他任何信息的其他信息,请随时提出。非常感谢任何帮助。谢谢!
Python
import base64
import mcrypt
encrypted_data = "placeholder: This is the encrypted data."
key = base64.b64decode("6vYJkO5beHNlwOm+aMqUTTzSpRw9jR3faHqu0wVoAG0=")
iv = base64.b64decode("EbuuKuVF4+DzDbWsvQi/ZA==")
m = mcrypt.MCRYPT("rijndael-128", "cbc")
m.init(key, iv)
decrypted_data = m.decrypt(encrypted_data)
红宝石
require 'base64'
require 'openssl'
encrypted_data = "placeholder: This is the encrypted data."
key = Base64.decode64("6vYJkO5beHNlwOm+aMqUTTzSpRw9jR3faHqu0wVoAG0=")
iv = Base64.decode64("EbuuKuVF4+DzDbWsvQi/ZA==")
d = OpenSSL::Cipher::AES128.new :CBC
d.decrypt
d.padding = 0
d.key = key
d.iv = iv
decrypted_data = d.update(encrypted_data) << d.final
【问题讨论】:
-
解密不是解码。密文包含随机字节,因此不应直接将其转换为字符串。
-
你的加密数据源是什么?它来自 Python 吗?
-
@owlstead 是的,你是对的!该程序会破坏数据。我相应地更改了代码。
-
@tsundoku 数据是从不同的服务器加载的。我不知道使用哪种编程语言来加密数据。为什么这很重要?
-
有几个设置需要调整,例如如果你设置
d.padding = 0,从这里:stackoverflow.com/questions/19661508/…
标签: python ruby encryption openssl