www.adminn.cn
站长正能量分享网!

php get_magic_quotes_gpc()函数用法介绍

AD:阿里云服务器企业会员更优惠 腾讯云香港,韩国免备案服务器1.8折优惠

magic_quotes_gpc函数在php中的作用是判断解析用户提示的数据,如包括有:post、get、cookie过来的数据增加转义字符“\\”,以确保这些数据不会引起程序,特别是数据库语句因为特殊字符引起的污染而出现致命的错误.

在magic_quotes_gpc=On的情况下,如果输入的数据有

单引号(’)、双引号(”)、反斜线()与 NUL(NULL 字符)等字符都会被加上反斜线,这些转义是必须的,如果这个选项为off,那么我们就必须调用addslashes这个函数来为字符串增加转义.

正是因为这个选项必须为On,但是又让用户进行配置的矛盾,在PHP6中删除了这个选项,一切的编程都需要在magic_quotes_gpc=Off下进行了,在这样的环境下如果不对用户的数据进行转义,后果不仅仅是程序错误而已了,同样的会引起数据库被注入攻击的危险,所以从现在开始大家都不要再依赖这个设置为On了,以免有一天你的服务器需要更新到PHP6而导致你的程序不能正常工作.

当magic_quotes_gpc=On的时候,函数get_magic_quotes_gpc()就会返回1

当magic_quotes_gpc=Off的时候,函数get_magic_quotes_gpc()就会返回0

因此可以看出这个get_magic_quotes_gpc()函数的作用就是得到环境变量magic_quotes_gpc的值。既然在PHP6中删除了magic_quotes_gpc这个选项,那么在PHP6中这个函数我想也已经不复存在了。

php 判断是否开启get_magic_quotes_gpc功能了,以方便我们是否决定使用addslashes这个函数了,代码如下:

  1. function SQLString($c$t){ 
  2.  $c=(!get_magic_quotes_gpc())?addslashes($c):$c
  3.  switch($t){ 
  4.   case 'text'
  5.    $c=($c!='')?"'".$c."'":'NULL'
  6.    break
  7.   case 'search'
  8.    $c="'%%".$c."%%'"
  9.    break
  10.   case 'int'
  11.    $c=($c!='')?intval($c):'0'
  12.    break
  13.  } 
  14.  return $c

预防数据库攻击的正确做法,代码如下:

  1. <?php 
  2. function check_input($value
  3. // 去除斜杠 
  4. if (get_magic_quotes_gpc()) 
  5. $value = stripslashes($value); 
  6. // 如果不是数字则加引号 
  7. if (!is_numeric($value)) 
  8. $value = “‘” . mysql_real_escape_string($value) . “‘”; 
  9. return $value
  10. $con = mysql_connect(“localhost”, “hello”, “321″); 
  11. if (!$con
  12. die(‘Could not connect: ‘ . mysql_error()); 
  13. }//开源软件:phpfensi.com 
  14. // 进行安全的 SQL 
  15. $user = check_input($_POST['user']); 
  16. $pwd = check_input($_POST['pwd']); 
  17. $sql = “SELECT * FROM users WHERE 
  18. user=$user AND password=$pwd”; 
  19. mysql_query($sql); 
  20. mysql_close($con); 
  21. ?>

模板优惠价: (点击购买)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《php get_magic_quotes_gpc()函数用法介绍》
文章链接:https://www.adminn.cn/news/6468.html
本站资源模板仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。2021.5月起,网站调整,暂不再分享免费模板。谢谢理解

Adminn.Cn 站长分享圈

帝国CMS精品模板腾讯云优惠券,代金券

本站源码仅供本地环境下学习借鉴研究使用!

源码请勿用于任何涉灰站点!净化网络,站长更有责!

支付宝扫一扫打赏