3.PHP文件包含


<a href="#MIDDLE" ><h3>点击跳转到MIDDLE级别</h3></a><a href="#HIGN"><h3>点击跳转到HIGN级别<h3></a>

LOW级别:

1.看看能不能包含PHP的info函数:

首先让我们先修改一下allow_url_include的参数值允许远程文件包含。


image.png
2.看看能不能通过page参数包含并执行敏感文件:
image.png

<a id="MIDDLE">--------------------------------------------------------------------------------------------------------------------</a>

Middle级别:

<php
//Thepagewewishtodisplay
$file=$_GET['page'];
//Inputvalidation
$file=str_replace(array("http://","https://"),"",$file);
$file=str_replace(array("../","..\""),"",$file);
>
Medium级别的代码增加了str_replace函数,对page参数进行了一定的处理,将”http:// ”、”https:// ”、 ” ../”、”..\”替换为空字符,即删除。
1.通过双写http:// 实现绕过过滤
image.png
2.大小写混淆绕过
image.png

<a id="HIGN">--------------------------------------------------------------------------------------------------------------</a>

Hign级别:

<php
//Thepagewewishtodisplay
$file=$_GET['page'];
//Inputvalidation
if(!fnmatch("file*",$file)&&$file!="include.php"){
   //Thisisn'tthepagewewant!
echo"ERROR:Filenotfound!";
exit;
}
>

1.通过file协议的漏洞绕过: ../表示上一级目录


image.png

怎么防御?

1.关闭url_allow_include功能即可。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,778评论 18 399
  • 一、什么才是”远程文件包含漏洞”? 回答是:服务器通过php的特性(函数)去包含任意文件时,由于要包含的这个文件来...
    喜欢吃栗子阅读 2,695评论 1 4
  • 已经同步到gitbook,想阅读的请转到gitbook: Django 1.10 中文文档 URL dispatc...
    leyu阅读 14,262评论 0 16
  • 一. Java基础部分.................................................
    wy_sure阅读 3,839评论 0 11