0

0

php怎么写兼容魔术引号_php关闭或模拟魔术引号兼容技巧【技巧】

星夢妙者

星夢妙者

发布时间:2026-02-13 09:12:10

|

688人浏览过

|

来源于php中文网

原创

php 7.4+ 已彻底移除 magic_quotes_gpc,不存在该配置项;需删除所有 get_magic_quotes_gpc() 调用及兼容逻辑,并改用 filter_input() 和预处理语句确保安全。

php怎么写兼容魔术引号_php关闭或模拟魔术引号兼容技巧【技巧】

PHP 7.4+ 已彻底移除 magic_quotes_gpc,别再试图“关闭”它

魔术引号(magic_quotes_gpc)在 PHP 5.4.0 被标记为 deprecated,PHP 7.0 正式删除,7.4 及以后版本根本不存在这个配置项。如果你在 php.ini 里还找 magic_quotes_gpc = On 或试图用 set_magic_quotes_runtime() 关闭它——那说明你正在维护一段非常老的代码,或者误读了错误提示。

常见误判场景:

  • 看到报错含 magic_quotes 字样,其实是旧文档/框架残留注释或开发者手动调用已废弃函数
  • 迁移老项目时,发现输入数据多了一层反斜杠(如 don't),误以为是 magic quotes 生效,实则是代码里重复调用了 addslashes() 或未适配 get_magic_quotes_gpc() 的兼容逻辑

如何安全移除遗留的 magic_quotes 兼容代码

老项目常有类似这样的防御性代码:

if (get_magic_quotes_gpc()) {
    $_GET = array_map('stripslashes', $_GET);
    $_POST = array_map('stripslashes', $_POST);
    $_COOKIE = array_map('stripslashes', $_COOKIE);
}

这段代码在 PHP 5.4+ 会触发 Deprecated: Function get_magic_quotes_gpc() is deprecated;在 PHP 7+ 直接报 Fatal error: Uncaught Error: Call to undefined function get_magic_quotes_gpc()

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

正确做法是:直接删掉整段逻辑,并检查后续是否依赖“已被 stripslashes 的数据”。更稳妥的方式是全局统一过滤入口,例如:

醒蓝AI
醒蓝AI

一键快速生成Al形象照、证件照、写真照的强大AI换脸软件

下载
  • 确认所有外部输入($_GET$_POST 等)不再被自动转义
  • 改用 filter_input() 显式过滤,比如 filter_input(INPUT_GET, 'id', FILTER_SANITIZE_NUMBER_INT)
  • 数据库写入前,统一使用预处理语句(PDO/MySQLi),而非拼接 SQL + 手动 addslashes()

为什么不能“模拟” magic_quotes_gpc 行为

有人想通过自动遍历 $_GET/$_POST 并对字符串调用 addslashes() 来“复刻”旧环境行为——这极其危险:

  • 现代框架(Laravel、Symfony)和 CMS(WordPress 5.0+、Drupal 8+)默认不依赖该机制,模拟反而导致双重转义(如 O'ReillyO\'Reilly
  • addslashes() 不等价于原 magic_quotes_gpc:它不处理 null 字节,也不覆盖所有注入向量,且对多字节编码(如 UTF-8)不可靠
  • JSON 请求体(file_get_contents('php://input'))、API 接口、CLI 参数完全不受影响,模拟逻辑极易遗漏

真正需要兼容的,不是“让新 PHP 像旧 PHP”,而是让旧业务逻辑适应无转义的原始输入。

检查和修复的关键点

运行以下代码快速定位风险点:

var_dump(function_exists('get_magic_quotes_gpc'));
// 输出 bool(false) 即表示该函数不存在(PHP 7+)

// 搜索项目中是否还存在:
// get_magic_quotes_gpc()
// set_magic_quotes_runtime()
// addslashes() 直接用于 SQL 拼接
// mysql_real_escape_string()(已废弃)

重点排查位置:

  • 全局初始化文件(如 init.phpcommon.php
  • 旧版 CMS 插件或第三方库(特别是 2012 年前的 PHP 类库)
  • 自定义的表单处理函数,尤其是带 if (get_magic_quotes_gpc()) 分支的

最易被忽略的是:有些代码把 stripslashes() 写在了数据库查询之后,而不是输入接收时,导致本不该处理的数据被误删反斜杠。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
PHP Symfony框架
PHP Symfony框架

本专题专注于PHP主流框架Symfony的学习与应用,系统讲解路由与控制器、依赖注入、ORM数据操作、模板引擎、表单与验证、安全认证及API开发等核心内容。通过企业管理系统、内容管理平台与电商后台等实战案例,帮助学员全面掌握Symfony在企业级应用开发中的实践技能。

82

2025.09.11

laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

329

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

285

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

560

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

379

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

128

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

78

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

69

2025.08.05

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

热门下载

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

精品课程

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

共137课时 | 11.7万人学习

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号