PHP 魔术引号

1、魔术引号的作用是什么?

?

  魔术引号设计的初衷是为了让从数据库或文件中读取数据和从请求中接收参数时,对单引号、双引号、反斜线、NULL加上一个一个反斜线进行转义,这个的作用跟addslashes()的作用完全相同。

2、转义的作用?

?

  正确地接收和读取数据,从而正确地执行SQL语句。比如从前台接收一个参数,假定为$para,后台接收到参数后要执行一条查询的SQL语句,拼接sql语句时,把参数传进入,类似于

  

”SELECT * FROMTABLEWHEREFIELD1= $para ANDFILED2= ‘xxx’”的形式。

?

  如果参数中含有双引号如”value,那SQL语句就会变成

  

“SELECT * FROMTABLEWHEREFIELD1= “value ANDFIELD2= ‘xxx’”

?

  本来是执行上面的红色语句,结果变成下面的红色语句,并不是我们想要的,需要让系统能够认清真正地SQL语句起始符和结束符,这就需要转义了,转义完变成

  

“SELECT * FROMTABLEWHEREFIELD1= \“value ANDFIELD2= ‘xxx’”;

?

  真正执行的SQL语句如上,达到想要的查询表中,字段FIELD1为”value和字段FIELD2为xxx的数据。

3、为什么在PHP5.4.0之后取消了魔术引号特性?

?

(1)可移植性

  编程时认为其打开或并闭都会影响到移植性。可以用 get_magic_quotes_gpc() 来检查是否打开,并据此编程。

(2)性能

  由于并不是每一段被转义的数据都要插入数据库的,如果所有进入 PHP 的数据都被转义的话,那么会对程序的执行效率产生一定的影响。在运行时调用转义函数(如 addslashes())更有效率。 尽管 php.ini-dist 默认打开了这个选项,但是 php.ini-recommended 默认却关闭了它,主要是出于性能的考虑。

(3)方便

  由于不是所有数据都需要转义,在不需要转义的地方看到转义的数据就很烦。比如说通过表单发送邮件,结果看到一大堆的 ‘。针对这个问题,可以使用 stripslashes() 函数处理。

4、php.ini相关配置

?


魔术引号配置选项


描述


运行时改变


PHP中的默认值


magic_quotes_gpc


如果打开的话,影响 到 HTTP 请求数据(GET,POST 和 COOKIE)。


NO


ON


magic_quotes_runtime


如果打开的话,大部 份从外部来源取得数据并返回的函数,包括从数据库和文本文件,所返回的数据都会被反斜线转义。(前提是magic_quotes_gpc = On)


NO


OFF


Magic_quotes_sybase


当关闭时,所有的 (单引号),"(双引号),(反斜线)和 NULL 字符都会被自动加上一个反斜线进行转义。这和 addslashes() 作用完全相同。

如果打开的话,将会使用单引号对单引号进行转义而非反斜线。此选项会完全覆盖 magic_quotes_gpc。如果同时打开两个选项的话,单引号将会被转义成 。而双引号、反斜线 和 NULL 字符将不会进行转义。

(前提是magic_quotes_gpc = On)


YES


OFF

 

  set_magic_quotes_runtime(),设置当前magic_quotes_runtime 配置选项的激活状态,0为关闭,1为开启。啥意思呢?这样理解,如是set_magic_quotes_runtime(1)或是配置文件中magic_quotes_runtime为true(这个在php.ini中配置),那么php脚本读取文件或是从数据库中读取数据,遇到反斜线(\)、单引号(‘)、双引号(")、NULL时,会在前面自动加上转义字符,变成\\、\‘、\”、\NULL;若是关闭的话,也就是set_magic_quotes_runtime(0)magic_quotes_runtime为false,那么便会转义,此时可以借助addslashes进行转义。

  magic_quotes_gpc(),当此值为1时,会对HTTP请求中的G($_GET)、P($_POST)、C($_COOKIE)单双引号和反斜线进行转义;反之则不会。该操作一般见于表单提交的数据库操作,若是值为0时,便用addslashes进行转义存入数据库中,取出时再用stripslashes函数把反斜线给去掉。

  PS.在PHP 5.4版本时,魔术引号被移除了,因此转义都需要加上addslashes函数。

 
时间: 2024-10-01 14:57:13

PHP 魔术引号的相关文章

编写不受魔术引号影响的php应用

原创作品author流水孟春,转载请注明出处lib.cublog.cn 阅读前提:你必须看过php手册上的"第IV部分安全"的"第10章魔术引号".如果没看过,也没问题,现在马上花10分钟先看一下php手册上的这东西. 魔术引号(Magic Quote)是一个自动将进入 PHP 脚本的数据进行转义的过程 你可能想让你的程序兼容多个数据库,但你使用的不同的数据库可能使用不同的转义符,而我们的程序又有可能运行在不同的php.ini配置的主机上,关于magic_quote

php之魔术引号

什么是魔术引号?当sql句中含有单引号,双引号,反斜杠和NUL时,这时候如果不对这些符号进行转义,写入数据库时就会出错,而魔术引号magic_quotes_gpc()就是对这些符号进行转义以便能把数据正确写入数据库. get_magic_quotes_gpc()获取当前magic_quotes_gpc配置选项设置,如果magic_quotes_gpc处于on,则返回1,magic_quotes_gpc处于off,则返回0,在PHP5.4.0起将始终返回false. magic_quotes_gp

过狗菜刀原理以及绕过魔术引号的配置

本文作者:i春秋签约作家--凉风 首先感谢@我是salf给我的灵感 我之前发了一个帖子:过了D盾扫描的一句话木马. 里面分析了一句话木马的原理,以及过狗.D盾的木马的编写. 传送门: https://bbs.ichunqiu.com/thread-25644-1-1.html tips:下文需要知道一句话木马的原理,可看上面说的帖子 tips2:还是在这里简单的说一下吧,例如木马 assert($_POST[XYZ]),会把用户post的 XYZ=asdfasdf中的asdfasdf作为php代

char函数绕过魔术方法注入

我目前学习到的绕过魔术引号的几种方法(如果知道还有别的请万望告之): 1.倘若服务端是GBK可以尝试宽字节注入 2.使用char函数绕过魔术引号进行注入 3.同char函数类似的函数,例如bin(转换为2进制),或者oct(转换为8进制) 本篇就是介绍char函数来进行绕过魔术引号来注入. 假设:select * from user where username = 'def'; 是可以等价于:select * from user where username = char(100,101,10

对VAuditDemo的一次审计

拿到代码,首先先观察index.php入口文件. 1 <?php 2 require_once('sys/config.php'); 3 require_once('header.php'); 4 ?> 5 <div class="row"> 6 <?php 7 /* Include */ 8 if (isset($_GET['module'])){ 9 include($_GET['module'].'.inc'); 10 }else{ 11 ?>

php各版本的姿势(2017-02-15更新)

今天被p师傅的黑魔法给震惊到啦,我一定是学了假php,仔细想想,其实对php版本更新并没有在意多少,都是活在5.3那个版本,可现在都是7.0啦!另外的是在很多时候测试代码的时候,也很依靠版本问题. http://php.net/manual/zh/appendices.php php5.2以前 1.__autoload加载类文件,但只能调用一次这个函数,所以可以用spl_autoload_register加载类 php5.3 1.新增了glob://和phar://流包装glob用来列目录,绕过

PHP学习笔记A

//语法错误(syntax error)在语法分析阶段,源代码并未被执行,故不会有任何输出. /* [命名规则] */常量名 类常量建议全大写,单词间用下划线分隔 // MIN_WIDTH变量名建议用下划线方式分隔 // $var_name函数名建议用驼峰命名法 // varName定界符建议全大写 // <<<DING, <<<'DING'文件名建议全小写和下划线.数字 // func_name.php私有属性名.方法名建议加下划线 // private $_name

20150411--Dede二次开发-01

目录 一.目前市场流行的电子商城系统 1 二.ecshop的介绍 1 三.安装 2 四.echsop 的目录结构 5 五.分析ecshop里面程序的架构 5 六.小试牛刀把面包屑导航改成两个大于号 6 1.根据php页面找出该页面对应的模板. 6 2.找到category.dwt模板文件,打开找到面包屑导航的位置 6 3.在library目录中找出  ur_here.lbi文件 7 七.init.php文件分析 9 八.完成在用户登录是, 可以使用邮箱登录. 11 九.完成余额显示: 15 十.

MySQL注入

SQL Injection Tutorial by Marezzi (MySQL) SQL注入教程由Marezzi(MySQL的) In this tutorial i will describe how sql injection works and how to在本教程中,我将介绍如何SQL注入工程和如何use it to get some useful information.用它来获取一些有用的信息. First of all: What is SQL injection?首先:什么是S