北京pk10五码公式教程:升级 PHP7.1 后 openssl 解密 mcrypt AES 数据不兼容问题的处理方法

江西多乐彩11选5走势图 www.ptdvv.cn  更新时间:2018年07月02日 15:22:29   作者:loveyu   我要评论

这篇文章主要介绍了升级 PHP7.1 后 openssl 解密 mcrypt AES 数据不兼容问题的处理方法,需要的朋友可以参考下

这是一个创建于 374 天前的主题,其中的信息可能已经有所发展或是发生改变。

$key = "01234567891234560123456789123456";
$iv = "0123456789123456";
//原本的 mcrypt 加密
$en_data = base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, "0123456789123456", MCRYPT_MODE_CBC, $iv));
var_dump("mcrypt_encrypt:");
var_dump(bin2hex(base64_decode($en_data)));
var_dump($en_data);
$de_data = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, base64_decode($en_data), MCRYPT_MODE_CBC, $iv);
var_dump("mcrypt_decrypt:");
var_dump($de_data);
//OpenSSL 加密
$en_data = base64_encode(openssl_encrypt("0123456789123456", "aes-128-cbc", $key, OPENSSL_RAW_DATA|OPENSSL_ZERO_PADDING, $iv));
var_dump("openssl_encrypt:");
var_dump(bin2hex(base64_decode($en_data)));
var_dump($en_data);
$de_data = openssl_decrypt(base64_decode($en_data), "aes-128-cbc", $key, OPENSSL_RAW_DATA|OPENSSL_ZERO_PADDING, $iv);
var_dump("openssl_decrypt:");
var_dump($de_data);
var_dump(openssl_error_string());

输出

string 'mcrypt_encrypt:' (length=15)
string '098edde21e92cbc01078469509f877de' (length=32)
string 'CY7d4h6Sy8AQeEaVCfh33g==' (length=24)
string 'mcrypt_decrypt:' (length=15)
string '0123456789123456' (length=16)
string 'openssl_encrypt:' (length=16)
string '434b1b1eb39024f270672bcd16bfe7f9' (length=32)
string 'Q0sbHrOQJPJwZyvNFr/n+Q==' (length=24)
string 'openssl_decrypt:' (length=16)
string '0123456789123456' (length=16)
string 'error:0607A082:digital envelope routines:EVP_CIPHER_CTX_set_key_length:invalid key length' (length=89)

目前正在使用的是 PHP 的算法,使用了 32 位的秘钥和 16 位的向量。但是在 openssl 中这种加密出来的结果不一致,并且扔过来一个错误

不确定要如何才能处理用 mcrypt 加密的数据,用 openssl 解密,秘钥长度历史遗留问题没法改,libmcrypt 的源码看不懂它如何兼容过长的秘钥

第 1 条附言  ·  2017-06-23 12:04:08 +08:00

问题已解决:

$en_data = base64_encode(openssl_encrypt("0123456789123456", "aes-256-cbc", $key, OPENSSL_RAW_DATA|OPENSSL_ZERO_PADDING, $iv)); 
var_dump($en_data); 
$de_data = openssl_decrypt(base64_decode($en_data), "aes-256-cbc", $key, OPENSSL_RAW_DATA|OPENSSL_ZERO_PADDING, $iv); 
var_dump($de_data); 

换成 aes-256-cbc 即可,除了会有警告

总结

以上所述是小编给大家介绍的升级 PHP7.1 后 openssl 解密 mcrypt AES 数据不兼容问题的处理方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • ThinkPHP使用Ueditor的方法详解

    ThinkPHP使用Ueditor的方法详解

    这篇文章主要介绍了ThinkPHP使用Ueditor的方法,详细分析了thinkPHP框架整合Ueditor编辑器的具体步骤与相关实现技巧,需要的朋友可以参考下
    2016-05-05
  • 老生常谈PHP面向对象之注册表模式

    老生常谈PHP面向对象之注册表模式

    下面小编就为大家带来一篇老生常谈PHP面向对象之注册表模式。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • php实现信用卡校验位算法THE LUHN MOD-10示例

    php实现信用卡校验位算法THE LUHN MOD-10示例

    这篇文章主要介绍了php实现信用卡校验位算法THE LUHN MOD-10的示例,需要的朋友可以参考下
    2014-05-05
  • Symfony查询方法实例小结

    Symfony查询方法实例小结

    这篇文章主要介绍了Symfony查询方法,结合实例形式总结分析了createQuery与getQuery查询数据的具体使用技巧,需要的朋友可以参考下
    2017-06-06
  • PHP页面间传递值和保持值的方法

    PHP页面间传递值和保持值的方法

    这篇文章主要介绍了PHP页面间传递值和保持值的方法,传递值主要通过get和post提交,通过session和cookie保持数据,本文介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08
  • ThinkPHP中html:list标签用法分析

    ThinkPHP中html:list标签用法分析

    这篇文章主要介绍了ThinkPHP中html:list标签用法,较为详细的分析总结了ThinkPHP中html:list标签的定义、使用方法及相关注意事项,需要的朋友可以参考下
    2016-01-01
  • PHP实现微信发红包程序

    PHP实现微信发红包程序

    微信发红包是比较流行的一件事情,老老少少都会使用微信发红包,接下来,小编给大家分享在生活中常碰到的一个php实现微信发红包程序的算法,希望这个程序对大家在做微信卡发的朋友有所帮助
    2015-08-08
  • PHP递归遍历指定文件夹内的文件实现方法

    PHP递归遍历指定文件夹内的文件实现方法

    下面小编就为大家带来一篇PHP递归遍历指定文件夹内的文件实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11
  • php多维数组去掉重复值示例分享

    php多维数组去掉重复值示例分享

    这篇文章主要介绍了php多维数组去掉重复值示例,需要的朋友可以参考下
    2014-03-03
  • 在Thinkphp中使用ajax实现无刷新分页的方法

    在Thinkphp中使用ajax实现无刷新分页的方法

    这篇文章主要介绍了在Thinkphp中使用ajax实现无刷新分页的方法的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下
    2016-10-10

最新评论

534| 983| 565| 771| 23| 32| 721| 893| 90| 940|