”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > Can I Migrate My Encryption from Mcrypt to OpenSSL, and Decrypt Mcrypt-Encrypted Data Using OpenSSL?

Can I Migrate My Encryption from Mcrypt to OpenSSL, and Decrypt Mcrypt-Encrypted Data Using OpenSSL?

发布于2024-12-21
浏览:998

Can I Migrate My Encryption from Mcrypt to OpenSSL, and Decrypt Mcrypt-Encrypted Data Using OpenSSL?

Upgrading my encryption library from Mcrypt to OpenSSL

Can I upgrade my encryption library from Mcrypt to OpenSSL? In OpenSSL, is it possible to decrypt data encrypted with Mcrypt? Two different posts provide conflicting information.

Question: Is it possible to upgrade my encryption library from Mcrypt to OpenSSL? If so, how?

Answer: Yes, it is possible to upgrade your encryption library from Mcrypt to OpenSSL.

Question: Can I decrypt data encrypted with Mcrypt using OpenSSL?

Answer: Yes, it is possible to decrypt data encrypted with Mcrypt using OpenSSL.

Here is a code example of how you can decrypt data encrypted with Mcrypt using OpenSSL:

public function decrypt($data, $key) {
    $salt = substr($data, 0, 128);
    $enc = substr($data, 128, -64);
    $mac = substr($data, -64);

    list ($cipherKey, $macKey, $iv) = $this->getKeys($salt, $key);

    if ($mac !== hash_hmac('sha512', $enc, $macKey, true)) {
        return false;
    }

    $dec = openssl_decrypt($enc, $this->cipher, $cipherKey, OPENSSL_RAW_DATA, $iv);

    return $dec;
}

Additional Notes:

  • The openssl_decrypt() function requires the iv parameter to be the same length as the block size of the cipher being used.
  • If the iv parameter is not the same length as the block size of the cipher being used, you will need to use the openssl_decrypt() function in CBC mode.

Test:

The following code can be used to test the decrypt() function:

$keys = [
    'this is a secret key.',
    'G906m70p(IhzA5T&5x7(w0%a631)u)%D6E79cIYJQ!iP2U(xT13q6)tJ6gZ3D2wi&0")7cP5',
    chr(6) . chr(200) . chr(16) . 'my key ' . chr(3) . chr(4) . chr(192) . chr(254) . ' zyx0987!!',
    'and finally one more key to test with here:',
];


$data = [
    'A',
    'This is a test',
    'now test encrypting something a little bit longer with 1234567890.',
    '$length = mcrypt_get_block_size(MCRYPT_BLOWFISH, MCRYPT_MODE_CBC); $last = ord($data[strlen($data) - 1]);',
    'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec sit amet pharetra urna. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Ut fringilla, quam sed eleifend eleifend, justo turpis consectetur tellus, quis tristique eros erat at nibh. Nunc dictum neque vel diam molestie fermentum. Pellentesque dignissim dui quis tortor eleifend, ut maximus elit egestas. Donec posuere odio et auctor porta. Quisque placerat condimentum maximus. Curabitur luctus dolor eget sem luctus, in dignissim tortor venenatis. Mauris eget nulla nisl.',
];

$failures = 0;

foreach ($data as $datum) {
    foreach ($keys as $key) {
        $enc = new Encryption(MCRYPT_BLOWFISH, MCRYPT_MODE_CBC);

        $encrypted = $enc->encrypt($datum, $key);

        $dec = new EncryptionOpenSsl('bf-cbc');

        $decrypted = $dec->decrypt($encrypted, $key);

        if (strcmp($datum, $decrypted) !== 0) {
            echo "Encryption with key '$key' of '$datum' failed.  '$decrypted' != '$datum'<br><br>\n\n";
            $failures++;
        }
    }
}

if ($failures) {
    echo "$failures tests failed.<br>\n";
} else {
    echo "ALL OKAY<br>\n";
}
最新教程 更多>
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-12-21
  • 尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    解决 PHP 中的 POST 请求故障在提供的代码片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"检查 $_POST数组:表单提交后使用 var_dump 检查 $_POST 数...
    编程 发布于2024-12-21
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-12-21
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-12-21
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-12-21
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-12-21
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2024-12-21
  • 插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入记录时如何解决“一般错误:2006 MySQL 服务器已消失”介绍:将数据插入 MySQL 数据库有时会导致错误“一般错误:2006 MySQL 服务器已消失”。当与服务器的连接丢失时会出现此错误,通常是由于 MySQL 配置中的两个变量之一所致。解决方案:解决此错误的关键是调整wait_tim...
    编程 发布于2024-12-21
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-12-20
  • 如何在 Python 中访问和处理命令行参数?
    如何在 Python 中访问和处理命令行参数?
    在 Python 中处理命令行参数在 Python 中,命令行参数位于名为 sys.argv 的列表中。要访问这些参数,请使用以下语法:import sys # Print all command line arguments print("\n".join(sys.argv))...
    编程 发布于2024-12-20
  • Python If 语句中逻辑 AND (&&) 运算符的等价物是什么?
    Python If 语句中逻辑 AND (&&) 运算符的等价物是什么?
    Python中的If语句中&&(逻辑与)的等价是什么?在Python中,无法像其他编程语言那样使用&&作为逻辑与运算符。当使用if语句时,必须使用and关键字。示例:以下示例尝试使用&&作为逻辑与运算符,但会引发语法错误:if cond1 &amp;&amp; cond2:正确方法:...
    编程 发布于2024-12-20
  • 如何修改 Go 中作为函数参数传递的切片?
    如何修改 Go 中作为函数参数传递的切片?
    将切片作为函数参数传递并修改原始切片在 Go 中,将参数传递给函数是按值完成的,这意味着对参数所做的任何更改函数内的内容不会反映在原始变量中。当使用可变数据类型(例如切片)时,这可能会出现问题,因为附加到函数内的切片不会影响超出函数范围的原始切片。考虑以下示例:nums := []int{1, 2,...
    编程 发布于2024-12-20
  • 为什么模板类定义必须包含在头文件中?
    为什么模板类定义必须包含在头文件中?
    在头文件中包含模板类定义:必要性问题是为什么需要模板类的实现和声明驻留在同一头文件中。为了解决这个问题,至关重要的是要了解编译器需要访问整个模板定义(不仅仅是其签名)才能为模板的每个实例化生成代码。因此,函数定义必须移至标题。包含模型提供了对此要求的全面解释。本质上,当实例化模板类时,编译器会为该特...
    编程 发布于2024-12-20
  • 在 JavaScript 中使用浮点数时如何控制小数精度?
    在 JavaScript 中使用浮点数时如何控制小数精度?
    控制 JavaScript 中的小数精度在 JavaScript 中处理浮点数时,您可能会遇到需要控制小数点后显示的位数的情况观点。例如,您可能希望仅显示两位小数的价格。以固定精度格式化浮点型为了实现此目的,JavaScript 提供了 toFixed() 函数。该函数采用一个参数来指定要保留的小数...
    编程 发布于2024-12-20
  • 填充空 Python 列表时如何避免 IndexError?
    填充空 Python 列表时如何避免 IndexError?
    修复将元素分配给列表时的 IndexError尝试通过依次分配每个元素来创建列表时,您可能会遇到 IndexError如果目标列表最初为空。出现此错误的原因是您试图访问列表中不存在的索引。要解决此问题并将元素正确添加到列表中,您可以使用追加方法:for l in i: j.append(l)...
    编程 发布于2024-12-20

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3