PHP万能密码的实际作用分析

关于PHP的安全问题,一直是程序员们探讨的话题。如何能够保证程序的安全性,决定了帷幕代码质量的高低。说实话如果一个网站的前台都是注入漏洞,那么凭经验,PHP***密码进后台的几率基本上是***。#t#

网站建设哪家好,找成都创新互联公司!专注于网页设计、网站建设、微信开发、微信平台小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了千阳免费建站欢迎大家使用!

可是有的人说对PHP的站如果是GPC魔术转换开启,就会对特殊符号转义,就彻底杜绝了PHP注入。其实说这话的人没有好好想过,更没有尝试过用***密码进PHP的后台。

其实GPC魔术转换是否开启对用PHP***密码进后台一点影响也没有。如果你用这样的***密码'or'='or',当然进不去,理由是GPC开启的时候单引号会被转换。PHP注入时我常用的PHP***密码是:'or 1=1/*.

那我们分析一下为什么这可以进后台。如果sql语句这样写:"SELECT * FROM admin where name='".$_POST['name']."'andpassword='".$_POST['password']."'",那我们在帐号处输入***密码'or 1=1/*,密码随便输,sql语句就成了select * from admin where name='’or 1=1/*' and password='任意字符'。/*为mysql的注释符,这样后面的东西就都被注释掉了,也就是为什么密码随便输的原因。

假设GPC转换没有开启,那么请看:where name='’or 1=1(*/后面的东西被注释掉了),name='’的逻辑值为假,而后面的1=1逻辑值则为真,对于整体就成了假 or 真,最终的逻辑值还是真,就进后台了。

那么如果GPC转换开启了,就对单引号进行了转换。语句就变成了where name='\’or 1=1,在看一下和刚才有什么区别,无非是多了个\。name='\'与name=''的逻辑值一样,都为假,那1=1为真,总的sql语句的逻辑值不还是真吗?那有进不去后台的理由吗?

所以总的来说,PHP***密码可以这样写:'or 1=1/*,而GPC转换是否开启对它没有任何影响!所以请改变你的想法:存在字符型注入的php网站是可以用***密码'or 1=1/*的
 

网页标题:PHP万能密码的实际作用分析
转载注明:http://www.shufengxianlan.com/qtweb/news9/300309.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联