深入PHP magic quotes的详解


Posted in PHP onJune 17, 2013

特地查看了下手册,关于php  magic quotes,常见的几个设置如下,magic_quotes_gpc,magic_quotes_sybase,magic_quote_runtime,这几个函数是在php.ini中去配置的,从手册中可以看出从php5.3后已经废除了这些特性,所以强烈大家不要使用,在php.ini中关闭它。

深入PHP magic quotes的详解

这些函数的作用是对数据进行转义。防止sql注入的时候,很多人会这样写:

if(!get_magic_quotes_gpc()){
$post=addslashes($post);
}

如果开启了它们,会自动给你转义单引号(')、双引号(")、反斜线(\)与 NUL(null字符),其实就相当于调用addslashes函数。你可能会说这样不是很好嘛,安全性更高了,但是,你考虑代码移植性了吗?另外,对于上所有gpc($_GET,$_POST,$_COOKIE)的数据你都进行转义是否有必要?开销有多大?下面PHP点点通(phpddt.com)就对手册中关于Magic Quotes的详细说明:

1.magic_quotes_gpc

magic_quotes_gpc这个是用来设置GPC($_GET、$_POST、$_COOKIE)的魔术引用状态(在PHP4中也包含$_ENV)。当开启时,所有的单引号(single-quote),双引号(double quote),反斜线(backslash)和NUL's会被反斜线自动转义。当开启magic_quote_sybase为on时,只有单引号(singgle-quote)会被单引号转义为'',双引号、反斜线(backslash)和NUL's不受影响不会被转义。

深入PHP magic quotes的详解

2.magic_quote_runtime

magic_quote_runtime如果开启该选项,许多返回外部数据(数据库、文本)的函数将会被反斜线(backslash)转义。如果也开启magic_quote_sybase,则只有单引号(single-quote)会被单引号转义。

深入PHP magic quotes的详解

3.magic_quotes_sybase

magic_quotes_sybase如果设置此选项开启、在magic_quotes_gpc,magic_quotes_runtime开启的情况下单引号‘会被单引号'转移而不是被反斜线\转义。同时、此设置会完全覆盖magic_quotes_gpc的设置,即使magic_quotes_gpc被设置为on,双引号“、反斜线\和NUL's也不会被转义。

深入PHP magic quotes的详解

PHP 相关文章推荐
PHP 高手之路(三)
Oct 09 PHP
用Php编写注册后Email激活验证的实例代码
Mar 11 PHP
php生成图形(Libchart)实例
Nov 06 PHP
php 使用GD库为页面增加水印示例代码
Mar 24 PHP
php使用imagick模块实现图片缩放、裁剪、压缩示例
Apr 17 PHP
PHP易混淆函数的区别及用法汇总
Nov 22 PHP
WordPress中获取指定分类及其子分类下的文章数目
Dec 31 PHP
php简单解析mysqli查询结果的方法(2种方法)
Jun 29 PHP
如何打开php的gd2库
Feb 09 PHP
详解php语言最牛掰的Laravel框架
Nov 20 PHP
php获得刚插入数据的id 的几种方法总结
May 31 PHP
Yii框架模拟组件调用注入示例
Nov 11 PHP
php错误级别的设置方法
Jun 17 #PHP
PHP大小写问题:函数名和类名不区分,变量名区分
Jun 17 #PHP
修改php.ini以达到屏蔽错误信息并记录日志
Jun 16 #PHP
php fsockopen伪造post与get方法的详解
Jun 14 #PHP
探讨:parse url解析URL,返回其组成部分
Jun 14 #PHP
PHP可变函数的使用详解
Jun 14 #PHP
VIM中设置php自动缩进为4个空格的方法详解
Jun 14 #PHP
You might like
php分页函数完整实例代码
2014/09/22 PHP
php实现大文件断点续传下载实例代码
2019/10/01 PHP
js中的window.open返回object的错误的解决方法
2009/08/15 Javascript
13个绚丽的Jquery 界面设计网站推荐
2010/09/28 Javascript
jquery通过closest选择器修改上级元素的方法
2015/03/17 Javascript
手机端页面rem宽度自适应脚本
2015/05/20 Javascript
AngularJS教程 ng-style 指令简单示例
2016/08/03 Javascript
JavaScript数组去重由慢到快由繁到简(优化篇)
2016/08/26 Javascript
AngularJS中关于ng-class指令的几种实现方式详解
2016/09/17 Javascript
微信小程序 教程之事件
2016/10/18 Javascript
bootstrap配合Masonry插件实现瀑布式布局
2017/01/18 Javascript
javascript中json基础知识详解
2017/01/19 Javascript
ES7中利用Await减少回调嵌套的方法详解
2017/11/01 Javascript
jQuery实现模拟搜索引擎的智能提示功能简单示例
2019/01/27 jQuery
微信小程序中weui用法解析
2019/10/21 Javascript
微信小程序实现录音功能
2019/11/22 Javascript
Vue的transition-group与Virtual Dom Diff算法的使用
2019/12/09 Javascript
Python的Django框架使用入门指引
2015/04/15 Python
小米5s微信跳一跳小程序python源码
2018/01/08 Python
Python利用字典将两个通讯录文本合并为一个文本实例
2018/01/16 Python
Python用csv写入文件_消除空余行的方法
2018/07/06 Python
Python实现处理逆波兰表达式示例
2018/07/30 Python
win7+Python3.5下scrapy的安装方法
2018/07/31 Python
使用Django连接Mysql数据库步骤
2019/01/15 Python
python中嵌套函数的实操步骤
2019/02/27 Python
Python tornado上传文件的功能
2020/03/26 Python
Jupyter Notebook输出矢量图实例
2020/04/14 Python
HTML5 Plus 实现手机APP拍照或相册选择图片上传功能
2016/07/13 HTML / CSS
美国在线医疗分销商:MedEx Supply
2020/02/04 全球购物
社区学雷锋活动策划方案
2014/01/30 职场文书
建筑结构施工专业推荐信
2014/02/21 职场文书
“三支一扶”支教教师思想汇报
2014/09/13 职场文书
拾金不昧表扬信
2015/01/16 职场文书
医院办公室主任岗位职责
2015/04/01 职场文书
Python如何利用pandas读取csv数据并绘图
2022/07/07 Python
浅谈音视频 pts dts基本概念及理解
2022/08/05 数码科技