LOADING STUFF...

由php中字符offset特征造成的绕过漏洞详解

技术教程5小时前发布 北陌
14 0 0

由php中字符offset特征造成的绕过漏洞详解

php中的字符offset特性

php中的字符串存在一个非常有趣的特性,php中的字符串也可以像数组一样进行取值。

$test = “hello world”;
echo $test[0];

最后的结果就是h。

但是上述的这种特性有时会有意想不到的效果,看下面这段代码

$mystr = “hello world”;
echo $mystr[“pass”];

上述的代码的输出结果是h.这是为什么呢?其实很简单,和很多其他的语言一样,字符串在php中也像数组一样可以使用下标取值。$mystr[“pass”]中pass会被进行隐性类型转换为0,这样$mystr[0]的输出结果就是首字母h.

同样地,如果尝试如下的代码:

$mystr = “hello world”;
echo $mystr[“1pass”];

输出结果就是e.因为1pass会被隐性类型转换为1,$mystr[1]的输出结果就是第二个字母e.

字符特性造成的漏洞

下面这段代码是在在phpspy2006中用于判断登录时所使用的代码。

$admin[check] = “1”;
$admin[pass] = “angel”;
……
if($admin[check] == “1”) {
….
}

这样的验证逻辑如果利用上述的特性就很容易地就可以被绕过。$admin没有被初始定义为数组类型,那么当我们用字符串提交时phpsyp.php?admin=1abc时,php会取字符串1xxx的第一位,成功绕过if的条件判断。

上面那段代码是一个代码片段,接下来的这段代码是一段完整的逻辑代码,来自于php4fun中第5题,比较有意思。

© 版权声明

相关文章

暂无评论

暂无评论...