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

[BSidesCF 2020]Had a bad day1

看到页面有两个按钮

先随便点一个试一下,当我们点击之后发现url是有变动的

感觉url是有点东西的,可能是某种注入,先尝试一下sql注入,发现给出了报错

通过报错我们可以确定是文件包含漏洞,那我们试试php伪协议去读取一下index.php源代码试试,看看能不能通过源码分析出什么(这里有个php伪协议blog003-漏洞梳理篇之php伪协议_伪协议漏洞-CSDN博客)

发现文件多了一个后缀哦(那有可能是直接将文件与后缀名拼接起来),那么把输入的.php删除再来一次

这次返回了base64编码,尝试解密,得到index.php源码如下

<?php$file = $_GET['category'];if(isset($file)){if( strpos( $file, "woofers" ) !==  false || strpos( $file, "meowers" ) !==  false || strpos( $file, "index")){include ($file . '.php');}else{echo "Sorry, we currently only support woofers and meowers.";}}
?>

可以看到通过category进行get传参,然后category中是需要包含woofers、meowers和index三个中任意一个的,否则就会返回Sorry, we currently only support woofers and meowers.        这里是存在一个php特性,当我们在进行伪协议写入的时候,php会忽略没有含义的值。这样绕过了过滤。从而可以达到读取flag的目的。可以去看一下这篇文章[BSidesCF 2020]Had a bad day_mb5fdcad8719a20的技术博客_51CTO博客

也就是说当我们通过category去传入文件名的时候,category=woofers/flag的时候,index.php会在参数后面直接连接.php这个后缀,因此$file=woofers/flag.php,而在php中进行文件包含的时候会把woofers/给忽略掉,找到这个有意义的flag.php,从而到达利用php伪协议去读取flag.php的目的。

所以可以试着传入category的参数为woofers/flag

可以看到flag.php是被包含进去了但是没有被读取出来,看了别人的博客才知道php伪协议还可以套协议(学到了ovo),这里payload就是利用的这个知识点去构造的

payload:         category=php://filter/convert.base64-encode/woofers/resource=flag

这个伪协议套协议也就是去寻找woofers/flag,而前面说到php会忽略woofers所以这里就可以绕过index.php的过滤,从而读取到flag了

可以看到页面是返回来了一串base64编码,解码就可以得到flag.php的源码,如下

通过解码我们就可以看到源码中的flag了。

今天又学到了哈哈哈  Ovo   ovO OVO ovo 开心的一天       自嗨哈哈哈

参考文章:

003-漏洞梳理篇之php伪协议_伪协议漏洞-CSDN博客

buuctf-[BSidesCF 2020]Had a bad day(小宇特详解)-CSDN博客

[BUUOJ记录] [BSidesCF 2020]Had a bad day - Ye'sBlog - 博客园 (cnblogs.com)

[BSidesCF 2020]Had a bad day_mb5fdcad8719a20的技术博客_51CTO博客

http://www.lryc.cn/news/378241.html

相关文章:

  • 从媒体网站的频道划分看媒体邀约的分类?
  • Day40
  • linux基础 - 内核的基础概念
  • centos7系统使用docker-compose安装部署jenkins
  • 传染病报卡内容——丙型
  • 本地快速部署大语言模型开发平台Dify并实现远程访问保姆级教程
  • 《Cloud Native Data Center Networking》(云原生数据中心网络设计)读书笔记 -- 02 Clos拓扑
  • VUE3版本新特性
  • 【Oracle篇】Oracle数据库坏块处理:rman修复坏块实践与案例分析(第七篇,总共八篇)
  • 学懂C#编程:从一个简单的例子理解事件处理
  • 深入理解指针(2)
  • C#.Net筑基-集合知识全解
  • AI PPT生成器,一键在线智能生成PPT工具
  • stm32学习笔记---零基础入门介绍2
  • 搭建取图系统app源码开发,满足广泛应用需求
  • 语音质量评价方法之MOS
  • gorm简介
  • MySQL:SELECT list is not in GROUP BY clause 报错 解决方案
  • IPython的使用技巧
  • Spring Boot 多线程例子
  • java干货 线程池的分析和使用
  • 文本张量入门
  • js文字如何轮播?
  • Linux 五种IO模型
  • 深度解析响应式异步编程模型
  • 一个软件是如何开发出来的呢?
  • 宝塔板面有哪些优势
  • Mybatis中BaseEntity作用
  • IDEA2023中使用run Dashboard面板?实现批量运行微服务
  • 分数受限,鱼和熊掌如何兼得?专业or学校,这样选最明智!