文件包含 [SWPUCTF 2021 新生赛]include
打开题目
要求我们传入一个file进去,那我们get传入
/?file=1
?得到源码,并且提示我们flag在flag,php下
在源代码中,我们看见了allow_url_include函数,我们知道这涉及到文件包含。
一般默认allow_url_fopen是on的,那在这里告诉了我们allow_url_include也是on的,那我们就可以对url的文件当作代码执行。
那我们用php伪协议读取一下flag
payload:
?file=php://filter/read=convert.base64-encode/resource=flag.php
得到一串base64编码
我们base64解码一下
得到flag
知识点:
-
文件包含漏洞—allow_url_fopen和allow_url_include
概念:在文件包含漏洞中,PHP脚本环境中php.ini文件中通常会涉及到allow_url_fopen和allow_url_include两个参数,两个参数的开启或关闭影响文件包含漏洞的利用。
参数简介:
allow_url_fopen参数
简介:是否允许将URL(HTTP,HTTPS等)作为文件打开处理。
allow_url_fopen 它决定了 PHP 是否能够通过 URL (而非本地文件路径) 来打开文件 ,当 allow_url_fopen 是 On时,函数可 读取 或 写入 远程文件,如 fopen() 和 file_get_contents()。而为 Off 时,这些函数 只能用于操作本地文件。
allow_url_include参数
简介:是否允许includeI()和require()函数包含URL(HTTP,HTTPS)作为文件处理
在 PHP 中,
file
协议的使用不受allow_url_fopen
配置项的控制
allow_url_include 的生效依赖于 allow_url_fopen 配置项的开启。具体而言,当 allow_url_include 与 allow_url_fopen 两个配置项均被开启时,allow_url_include 才能够发挥作用。若仅有 allow_url_include 配置项被开启,则无法发挥 allow_url_include 配置项所起到的功能。
?
在开启 allow_url_fopen
配置项后,PHP 仅能够对远程文件进行读写等文件操作
。
在开启 allow_url_include
配置项后,PHP 将能够通过 include
等函数 将远程文件包含至当前文件并将其作为 PHP 代码进行执行
。
-
file协议
File协议主要用于访问本地计算机中的文件,就如同在Windows资源管理器中打开文件一样
基本格式:file:///文件路径
例如,我下访问本机桌面上的一张图片
?
知识点参考:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!