关于php引号及转义

什么是魔术引号

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

  一共有三个魔术引号指令:  

  • magic_quotes_gpc

        影响到 HTTP 请求数据(GET,POST 和 COOKIE)。不能在运行时改变。在     PHP 中默认值为 on。    

        参见 get_magic_quotes_gpc()。    

  • magic_quotes_runtime

        如果打开的话,大部份从外部来源取得数据并返回的函数,包括从数据库和文本文件,所返回的数据都会被反斜线转义。该选项可在运行的时改变,在     PHP 中的默认值为 off。    

        参见 set_magic_quotes_runtime() 和     get_magic_quotes_runtime()。    

  • magic_quotes_sybase

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

        如何取得其值参见 ini_get()。    



关闭魔术引号
magic_quotes_gpc 指令只能在系统级关闭,不能在运行时。也就是说不能用 ini_set()。

; Magic quotes  ;    ; Magic quotes for incoming GET/POST/Cookie data.  magic_quotes_gpc = Off    ; Magic quotes for runtime-generated data, e.g. data from SQL, from exec(), etc.  magic_quotes_runtime = Off    ; Use Sybase-style magic quotes (escape ' with '' instead of \').  magic_quotes_sybase = Off  


在运行时关闭魔术引号 magic_quotes_gpc

例如:

 <?php
if (get_magic_quotes_gpc()) {
   function stripslashes_deep($value)
   {
       $value = is_array($value) ?
                   array_map('stripslashes_deep', $value) :
                   stripslashes($value);
       return $value;
   }
   $_POST = array_map('stripslashes_deep', $_POST);
   $_GET = array_map('stripslashes_deep', $_GET);
   $_COOKIE = array_map('stripslashes_deep', $_COOKIE);
   $_REQUEST = array_map('stripslashes_deep', $_REQUEST);
}
?>


打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论