0

0

PHP7与PHP8加密函数差异_了解废弃函数替代写法【详解】

絕刀狂花

絕刀狂花

发布时间:2026-02-12 12:15:19

|

467人浏览过

|

来源于php中文网

原创

PHP7.1起mcrypt系列函数被彻底移除,须改用openssl_encrypt/decrypt并手动处理PKCS#7填充;PHP8.1起openssl_random_pseudo_bytes废弃,应改用random_bytes;PHP8强化hash_hmac和password_hash类型校验;PHP8.2要求gmp_import/export显式指定word_size参数。

php7与php8加密函数差异_了解废弃函数替代写法【详解】

PHP7中mcrypt_*系列函数彻底不可用

PHP7.1起已移除mcrypt扩展,不是弃用警告,而是直接报Fatal error: Uncaught Error: Call to undefined function mcrypt_encrypt()。很多老项目依赖mcrypt_encrypt()mcrypt_module_open()等做AES/CBC加解密,升级后必然崩。

替代方案只有openssl_encrypt()openssl_decrypt(),但参数顺序、填充方式、IV处理逻辑完全不同:

  • mcrypt默认使用零填充(Zero Padding),而openssl默认不自动填充,需手动补PKCS#7
  • mcryptmode参数是字符串如"cbc"openssl对应的是"AES-128-CBC"这类完整算法标识
  • mcrypt中IV长度由算法决定(如AES为16字节),openssl要求IV必须严格匹配加密模式所需长度,且不能复用

示例迁移要点:
mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC, $iv) → 改为openssl_encrypt($data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv),但前提是$data已按PKCS#7补足块长,且$key必须是16/24/32字节(对应AES-128/192/256)。

PHP8.1起openssl_random_pseudo_bytes()被废弃

这个函数在PHP8.1标记为Deprecated,PHP8.2正式移除。它曾常用于生成密钥或IV,但底层依赖已过时的伪随机数生成器(PRNG),安全性不足。

必须改用random_bytes()——它是密码学安全的、基于系统熵源(/dev/urandom、CryptGenRandom等):

立即学习PHP免费学习笔记(深入)”;

  • random_bytes(32)返回32字节二进制字符串,可直接作AES-256密钥
  • 生成IV也应同样调用:$iv = random_bytes(openssl_cipher_iv_length('AES-128-CBC'))
  • 注意:random_bytes()可能抛出Exception(如系统熵不足),生产环境需捕获RuntimeException

PHP8对hash_hmac()password_hash()无破坏性变更,但行为更严格

这两个函数本身没被废弃,但PHP8强化了类型校验和错误路径:

飞桨PaddlePaddle
飞桨PaddlePaddle

飞桨PaddlePaddle开发者社区与布道,与社区共同进步

下载
  • 传入nullarrayhash_hmac()$data参数,PHP7可能静默转成字符串,PHP8直接报TypeError
  • password_hash()在PHP8中对$options数组键名校验更严,比如错写'cost''Cost'会触发警告而非忽略
  • PHP8.0起password_hash()默认算法从bcrypt升级为argon2id(若编译时启用了libsodium),但仅当显式指定PASSWORD_ARGON2ID才生效;未指定时仍用bcrypt,兼容旧逻辑

建议:所有哈希操作统一用password_hash($pwd, PASSWORD_ARGON2ID, ['memory_cost'=>65536, 'time_cost'=>4]),并用password_verify()验证——它能自动识别散列格式,无需关心PHP版本差异。

PHP8.2移除了gmp_import()/gmp_export()$word_size参数默认值

这两个函数常用于RSA密钥处理(如将大整数转为二进制序列)。PHP8.2起,$word_size参数不再有默认值,必须显式传入1(字节)或4(32位字)等,否则报ArgumentCountError

典型影响场景是用phpseclib或自研RSA封装时:

  • 旧写法:gmp_import($binary) → 必须改为gmp_import($binary, 1, 'big')
  • 导出同理:gmp_export($gmp, 1, 'big'),第三个参数$order(大小端)也不能省略
  • 注意:gmp_import()在PHP8中已要求$binarystring,传intfloat会触发TypeError

密钥操作容错率低,任何字节错位都会导致解密失败,升级时务必逐个核对gmp_*调用点的参数数量与类型。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

688

2023.08.02

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

583

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

104

2025.10.23

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

243

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

685

2024.03.01

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

351

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

326

2023.10.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

508

2023.08.03

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

189

2026.02.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 11.6万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号