微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

[鹤城杯 2021]EasyP

<?PHP
include 'utils.PHP';

if (isset($_POST['guess'])) {
    $guess = (string) $_POST['guess'];
    if ($guess === $secret) {
        $message = 'Congratulations! The flag is: ' . $flag;
    } else {
        $message = 'Wrong. Try Again';
    }
}

if (preg_match('/utils\.PHP\/*$/i', $_SERVER['PHP_SELF'])) {
    exit("hacker :)");
}

if (preg_match('/show_source/', $_SERVER['REQUEST_URI'])){
    exit("hacker :)");
}

if (isset($_GET['show_source'])) {
    highlight_file(basename($_SERVER['PHP_SELF']));
    exit();
}else{
    show_source(__FILE__);
}
?> 

 这个题目出现了$_SERVER['PHP_SELF']

这个是你调用的脚本的路径

比如说这个题目它的值就是/index.PHP

如果你访问的是

http://1.14.71.254:28189/index.PHP/utils.PHP

那么它的值就会是/index.PHP/utils.PHP

而$_SEVER['REQUEST_URL']

它的值这个时候和$_SERVER['PHP_SELF']的值是一样的,

区别在于,如果你用get传参的时候$_SEVER['REQUEST_URL']是会加上那个参数的,而$_SERVER['PHP_SELF']不会。

 

然后是basename这个函数

这个函数是返回最后面一个/后面的名字。

 

这个函数一个可以利用的地方就是,如果传入的参数中出现了非ascii字符则会把它给丢弃。

 

最后是讲绕过正则

if (preg_match('/show_source/', $_SERVER['REQUEST_URI'])){
    exit("hacker :)");
}

 

 这个正则的绕过方法就是利用特性来绕过,可以用

 [

  (空格)

 +  

 .

上面那几个字符任何一个都行,都可以被处理成_

if (preg_match('/utils\.PHP\/*$/i', $_SERVER['PHP_SELF'])) {
    exit("hacker :)");
}

 

这个正则是匹配末尾有没有utils.PHP/

绕过办法很简单

因为后面要调用basename,所以可以利用中文来绕过,中文不属于ascii编码中的,所以可以payload

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐