PHP教程Magicquotes计算机软件及应用IT计算机专业资料.docxVIP

PHP教程Magicquotes计算机软件及应用IT计算机专业资料.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PHP 教程 Magic quotes 对于Magic quotes,对于PHPer而言是个老牛:常谈的问题。今天无意间看到篇文章,结合 PHP Manual以及其回复,在这里做个简单的汇总。 简而言之,Magic quotes开启后会自动转义输入的数据。其屮,所有的单引号C)、双引号 (”)、反斜线、和NULL字符都会被转义(增加个反斜线),其实这操作本质上调用的是 addslashes 函数。 为什么使丿LI Magic quotes 方便快捷 PHP的设计者在设计之初的构想就是能够快速方便的编程。例如插入数据库时,Magic quotes会自动将数据转义,这很方便。 对初学者有利 Magic quotes可以从一定程度上,让初学者带离脚本的安全风险。例如在没有任何保护措施 的代码卜,开启了 Magic quotes后会少很多的风险,例如注入问题。当然,单一使川此方 法,并不能完全阻止此类安全问题。 “我没冇权限去关闭” 很显然你已经可能意识到了这个问题,但是主机空间并非完全由白己控制。 为什么不使用Magic quotes 可移植性 无论此功能是否开启,它都会影响脚木的可移植性,因为它影响我们示续过滤数据的操作。 性能冋题 在获取所有的外部数据Z前都会被转义,这无疑会增加运行吋的花销(而且并不是所有的数 据都需要转义)。 造成闲惑 正如上述所言,并非所有的数据都需要被转义。有可能出现的一种情况,就是当你为了获取 未被转义的数据,而疯狂的”使用stripslashes函数。 PHP6已经不支持 PHP的设计者显然已经意识到了自己的“错误”,所以在PHP6中已经将英废弃。 如何禁用Magic quotes 按照本人观点,使用php.ini配置文件全局禁用Magic quotes是最靠谱的。参考下而的代 码 ;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_quotcs_runtimc = Off ;Use Sybase-style magic quotes (escape 1 with n instead of *). magic_quotes_sybase = Off 然而线上的主机可能无法让你修改php.ini文件,那么可以使用.htaccess文件禁用,加入 下面的代码 php_flag magic_quotcs_gpc Off 上述可移植的代码而言,无论是否禁用magic_quotes,数据必须保持一致。那么下面的代 码可以帮助您 ?php if (get_magic_quotes_gpc()) { function stripslashes_deep($value) { $value = is_array(Svalue) ? array_map(tstripslashes_deep\ $value): stripslashes(Svalue); return $valuc; 对于Magic quotes,对于PHPcr而言是个老生常谈的问题。今天无意间看到篇文章,结合 PHP Manual以及其回复,在这里做个简单的汇总。 简而言之,Magicquotes开启后会自动转义输入的数据。其中,所有的单引号C)、双引号 (”)、反斜线、和NULL字符祁会被转义(增加个反斜线),其实这操作本质上调用的是 addslashcs 函数。 为什么使用Magic quotes 方便快捷 PHP的设计者在设计Z初的构想就是能够快速方便的编程。例如插入数据库吋,Magic quotes会自动将数据转义,这很方便。 对初学者有利 Magic quotes可以从一定程度上,让初学者带离脚本的安全风险。例如在没有任何保护措施 的代码下,开启了 Magic quotes后会少很多的风险,例如注入问题。当然,单一使用此方 法,并不能完全阻止此类安全问题。 “我没冇权限去关闭” 很显然你已经可能意识到了这个问题,但是主机空间并非完全山自己控制。 为什么不使用Magic quotes 可移植性 无论此功能是否开启,它都会影响脚本的町移植性,因为它影响我们后续过滤数据的操作。 性能问题 在获収所有的外部数据之前都会被转义,这无疑会增加运行时的花销(而JJ?并不是所有的数 据都需要转义)。 造成因惑 正如上述所言,并非所有的数据都需要被转义。有可能出现的一种情况,就是当你为了获取 未被转义的数据,而“疯狂的”使用stripslashes函数。 PHP6已经不支持

文档评论(0)

ggkkppp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档