[ISITDTU 2019]EasyPHP

本文详细介绍了如何利用ISITDTU 2019 EasyPHP题目的限制,通过正则匹配和字符替换技巧构造webshell,包括对正则规则的理解、内置函数的筛选、异或和长度优化等步骤,最终成功执行命令获取flag。
摘要由CSDN通过智能技术生成

最近都在摸鱼,每天不知道干啥,没法静下心来做题,今天做了这个题,最后对于题目理解模棱两可,所以写一写wp来加固一下知识点,把无字母数字rce的内容巩固一下,这道题目涉及的点比较小,想了解更多的绕过姿势还得阅读p神的文章。

打开靶机,看到源码:

<?php
highlight_file(__FILE__);
$_ = @$_GET['_'];
if ( preg_match('/[\x00- 0-9\'"`$&.,|[{_defgops\x7F]+/i', $_) )
    die('rosé will not do it');
if ( strlen(count_chars(strtolower($_), 0x3)) > 0xd )
    die('you are so close, omg');
eval($_);
?>

源码意思是绕过两个if,最后eval执行命令

第一个正则匹配:

\x00- 0-9                              匹配\x00到空格(\x2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值