当前位置: 首页 > 面试题库 >

php:将mcrypt_encrypt转换为openssl_encrypt和OPENSSL_ZERO_PADDING问题

梁俊智
2023-03-14
问题内容

mcrypt_encrypt对于给定的$key,我有这个电话,$message并且$iv

$string = mcrypt_encrypt(MCRYPT_3DES, $key, $message, MCRYPT_MODE_CBC, $iv);

我想将mcrypt_encrypt通话更改为openssl_encrypt一个,以确保将来使用。

通过具有$mode = 'des-ede3-cbc'$mode = '3DES';和,$options = true我得到的响应更相似,但不完全相同。还有其他方法可以称其为完美匹配吗?

我正在为lorem-ipsum $message+
$key组合获得此(base64_encoded),所以我开始相信一个函数或另一个函数在加密之前会填充消息…

对于mcrypt

“ Y + JgMBdfI7ZYY3M9lJXCtb5Vgu + rWvLBfjug2GLX7uo =”

对于openssl

“ Y + JgMBdfI7ZYY3M9lJXCtb5Vgu + rWvLBvte4swdttHY =”

尝试使用$ options传递 OPENSSL_ZERO_PADDING ,但传递 1 以外的 任何值(
OPENSSL_RAW_DATAtrue )都会导致一个空字符串…

既不使用,OPENSSL_ZERO_PADDING也不OPENSSL_RAW_DATA | OPENSSL_ZERO_PADDING工作…
:(我正在使用“ OpenSSL 1.0.2g 2016年3月1日”。

已经阅读了此问答,但是对我没有帮助。并不是唯一有填充问题的人,但是到目前为止还没有解决的办法。(第二个答案谈到了 填充 添加
到mcrypt调用,我真的很想从openssl加密调用中 删除 填充…


问题答案:

如果不是块大小的倍数,则零填充输入数据。如果数据本身具有尾随零,则会导致结果不明确。显然,在这种情况下,OpenSSL不允许您使用零填充,这说明了错误的返回值。

您可以通过手动添加填充来避免这种情况。

$message = "Lorem ipsum";
$key = "123456789012345678901234";
$iv = "12345678";

$message_padded = $message;
if (strlen($message_padded) % 8) {
    $message_padded = str_pad($message_padded,
        strlen($message_padded) + 8 - strlen($message_padded) % 8, "\0");
}
$encrypted_mcrypt = mcrypt_encrypt(MCRYPT_3DES, $key,
    $message, MCRYPT_MODE_CBC, $iv);
$encrypted_openssl = openssl_encrypt($message_padded, "DES-EDE3-CBC", 
    $key, OPENSSL_RAW_DATA | OPENSSL_NO_PADDING, $iv);

printf("%s => %s\n", bin2hex($message), bin2hex($encrypted_mcrypt));
printf("%s => %s\n", bin2hex($message_padded), bin2hex($encrypted_openssl));

这将打印相等。

4c6f72656d20697073756d => c6fed0af15d494e485af3597ad628cec
4c6f72656d20697073756d0000000000 => c6fed0af15d494e485af3597ad628cec


 类似资料:
  • < code>PHP不再支持< code>mcrypt。我必须做一个OpenSSL替代方案,它具有完全相同的输出,因为我只能访问一半的代码库。我的尝试都失败了。正如你在下面看到的,OS和MC不匹配。我尝试了不同的< code>$methods和< code > OPENSSL _ RAW _ DATA | OPENSSL _ ZERO _ PADDING 的组合。 我哪里做错了?

  • 在PHP7及以上版本,mcrypt扩展已被废弃,不再作为官方支持。上述示例如何在PHP7以上的版本实现呢? 使用openssl库,这样实现,输出的结果不一致是什么原因呢?

  • 问题内容: 我正在尝试将xml中的xml转换为json。如果我使用简单的xml和json_encode进行简单的转换,则xml中的任何属性都不会显示。 所以我试图像这样手动解析它。 状态的输出不是 我究竟做错了什么? XML: 输出: var dump: 问题答案: 我想到了。json_encode处理对象的方式与处理字符串的方式不同。我将该对象转换为字符串,现在可以正常工作。

  • 问题内容: 我正在使用一个小脚本将PDF转换为JPG。可以,但是质量很差。 剧本: 还有一件事,我想保留PDF的原始大小,但转换会裁剪JPG的大小。 问题答案: 可以使用完成,但是您需要在加载图像之前进行。尝试这样的事情:

  • 问题内容: 有人可以帮助我将php regex转换为java regex吗? 太好了,如果您能帮助我,我将不胜感激,因为我对正则表达式的了解不强。 我如何理解php中的函数与Java中的函数相同?。因此在Java代码中将是这样。 但是此代码无法正常工作,因为我怎么知道php中的regex与java不同。 拜托,有人帮我!非常感谢)) 更新 最终结果是 问题答案: 对于此PHP正则表达式: 在Jav

  • 问题内容: myArray是: 我想将其转换为JSON,例如: 我试过了: 但这正在返回: 问题答案: 您的问题是非顺序索引。 Php数组必须具有要编码为JSON数组的索引。 您可以使用array_values重置数组键: