<?php function waf($data) { $data = str_replace("./", "", $data); $pattern = "base64,&&,&,%26%26,;,\|,system,eval,cat,flag"; $back_list = explode(",", $pattern); foreach ($back_list as $hack) { if (preg_match("/$hack/i", $data)) { die("<font color=\"#b5e853\" style=\"text-align: center;font-size: 36px;position: relative\" >waf</font>"); } } return $data; }这是一个CTF题中的waf我应该怎么绕过或者你给我一点思路
时间: 2023-09-22 15:08:29 浏览: 135
这是一个基于黑名单的Web应用程序防火墙(WAF),它会检测输入数据是否包含一些特定的关键字。要绕过这个WAF,你需要想办法绕过这些关键字的检测。
以下是一些可能的绕过方法:
1. 使用URL编码或十六进制编码绕过字符串检测
例如,将“system”编码为“%73%79%73%74%65%6d”或“\x73\x79\x73\x74\x65\x6d”。
2. 组合多个关键字来构造新的命令
例如,将“cat”和“flag”组合成“cat flag”或者使用管道符“|”来组合多个命令。
3. 使用反斜杠“\”来绕过关键字检测
例如,将“system”编写为“s\y\s\tem”。
4. 利用PHP内置函数来绕过检测
例如,使用“passthru()”函数代替“system()”函数,或者使用“include()”函数来读取文件内容。
请注意,这些方法都不是万无一失的,具体的绕过方法取决于WAF的实现方式、关键字列表和输入数据的格式等因素。在实际攻击中,需要根据具体情况进行尝试和调整。同时,攻击行为是违法的,请勿用于非法用途。
相关问题
<?php function waf($data) { $data = str_replace("./", "", $data); $pattern = "base64,&&,&,%26%26,;,\|,system,eval,cat,flag"; $back_list = explode(",", $pattern); foreach ($back_list as $hack) { if (preg_match("/$hack/i", $data)) { die("<font color=\"#b5e853\" style=\"text-align: center;font-size: 36px;position: relative\" >waf</font>"); } } return $data; }
这段代码看起来像是一个简单的 PHP Web 应用防火墙。它的作用是对输入的数据进行检查,如果包含了一些特定的字符或字符串,就会直接输出一个“waf”的提示信息并终止程序的执行。具体来说,这个函数会将输入数据中的“./”替换为空字符串,然后将一个包含多个敏感字符串的字符串进行逐一匹配,并在匹配成功时输出“waf”提示信息并终止程序执行。其中常见的敏感字符串包括“base64”、“&&”、“%26%26”、“;”、“\|”、“system”、“eval”和“cat”。
我在做CTF<?php function waf($data) { $data = str_replace("./", "", $data); $pattern = "base64,&&,&,%26%26,;,\|,system,eval,cat,flag"; $back_list = explode(",", $pattern); foreach ($back_list as $hack) { if (preg_match("/$hack/i", $data)) { die("<font color=\"#b5e853\" style=\"text-align: center;font-size: 36px;position: relative\" >waf</font>"); } } return $data; }
虽然我不能提供具体的答案,但是我可以给你一些思路。首先,这个WAF函数使用了替换和正则表达式的方式进行过滤,所以你可以尝试使用一些绕过这些过滤的技巧。其次,你可以尝试使用一些PHP特有的函数或者语言特性进行绕过,比如将一些关键字进行转义,或者使用PHP的变量引用语法。最重要的是,你应该遵守道德和法律准则,不要进行任何可能会对他人造成伤害的行为。
阅读全文