代码审计中的文件包含漏洞

0x00 背景

文件包含漏洞是php语言的一大特性。文件包含的意思是,服务器在执行PHP文件时,可以通过文件包含函数加载另一个文件中的PHP代码并执行,这会为开发者节省大量的时间。而文件包含漏洞的出现在于服务器没有对要包含的来源文件进行审查,导致黑客进行了任意文件的读取甚至执行。本文以代码审计的形式研究文件包含漏洞的原理、挖掘形式、防御方案及缺陷。

0x01 文件包含漏洞的产生原理

文件包含漏洞出现的前提是服务器开启allow_url_include选项,在此前提下就可以通过php的某些特性函数(include(),require()和include_once(),require_once())利用url去动态包含文件,区别在于include()、include_once()遇到错误继续执行,而require、require_once遇到错误直接退出程序。如果在php配置中开启了allow_url_fopen,那么就可以进行远程文件包含。最简单的文件包含如下:

 

<?php
$file=$_GET['page'];
include($file) ?>

 

 这里用户以GET形式提交的页面传入变量file,随后被include函数包含,中途没有进行任何过滤和规范性检查,黑客往往利用这种漏洞进行任意代码执行或文件读取。

0x02 文件包含漏洞的挖掘形式

文件包含漏洞通常有两种挖掘方式,第一种是常见的的关键词挖掘。直接搜索include(),require(),include_once(),require_once()四个函数,然后进行变量回溯观察是否用户自主可控即可。第二种方式是根据功能进行有针对性的代码审计,文件包含漏洞通常出现在模板加载处,这里传递的参数就是我们审计的的重点,我们在代码审计的时候可以通读部分代码挖掘漏洞。

本地文件包含

本地文件包含(LFI)顾名思义就是包含本机的为文件,通常出现在模板加载处,我们把上面的代码放入Web目录,同时我们在同目录下新建一个文件,名为phpinfo.php,内容为:

 

<?php
phpinfo();
?>

 

 提交请求:http://127.0.0.1/include.php?page=phpinfo.php,服务器执行了phpinfo()操作。

远程文件包含

远程文件包含(RFI)可以包含其他主机的远程文件,相比于LFI,RFI的威胁更大但是比较少见。常见RFI的代码如下:

1 <?php
2 include($_GET['url']);
3 ?>

如果存在www.testrfi.com/test.txt,内容为<?php phpinfo(); ?>,我们在url参数里传入http://testrfi.com/test.txt,访问后就会反回本机的phpinfo。

文件包含的截断

上面的的代码都是理想状态下的文件包含,事实上绝大多数的文件包含都需要配合截断进行,因为我们不能写入以.php为拓展名的文件,例如如下程序:

<?php
$a = $_GET['file'];
include $a.'.html.php';
?>

这种情况我们常见的有三种截断方式

1.%00截断

在PHP版本低于5.3并且GPC未开启的情况下,我们提交请求127.0.0.1/test.php?file=1.txt%00即可进行截断。

2.点斜杠(./)截断

在PHP版本低于5.3的情况下,Windows下连续240个点(.)或者(./)可以截断,Linux下连续2038个/.可以截断。

3.远程包含的?截断

1 <?php
2 include($_GET['url'].'.php');
3 ?>

在上面这段代码中,我们在testrfi.com主机的Web目录下创建phpinfo.txt,提交请求127.0.0.1/test.php?url=phpinfo.txt?后发现返回了主机的phpinfo信息。这是因为服务器解析的内容为127.0.0.1/test.php?url=phpinfo.txt?.php,它把?后面的内容作为了参数,因此实现了截断。

0x02 防御方案及缺陷

文件包含漏洞的防御主要列举三种常见的防御措施

黑名单

 

<?php$file=$_GET['page'];$file=str_replace(array("http://","https://"),"",$file);
$file=str_replace(array("../","..\""),"",$file);include ($_GET['file']);
?>

 

这里的黑名单依然采用了危险函数str_replace(),过滤掉了http://、https://、../、..\。在之前的文章中我们提到了可以通过双写绕过,我们提交如下请求即可进行文件包含:

http://127.0.0.1?test.php?page=…/./…/./…/./…/./…/./…/./…/./…/./…/./…/./php.ini

文件名匹配

php中有一个函数为fnmatch(),这个函数可以根据指定的模式来匹配文件名或字符串,利用这个函数我们提出了第二种防御方案:

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

这里fnmatch()函数要求page参数的开头必须是file,服务器才会去包含相应的文件。这里我们可以通过file协议进行绕过,提交请求即可进行文件包含:

http://127.0.0.1/test.php?page=file:///D:/phpstudy/lfi/php.ini

白名单

白名单是最安全防御机制,将允许包含的文件列举到白名单内,不在白名单里的文件不得进行包含。唯一的缺点是在大型Web程序中白名单的维护比较复杂。

 

转载于:https://www.cnblogs.com/richardlee97/p/10542057.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/569637.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

蓝桥杯第九届省赛JAVA真题----螺旋折线

标题&#xff1a;螺旋折线 如图p1.pgn所示的螺旋折线经过平面上所有整点恰好一次。 对于整点(X, Y)&#xff0c;我们定义它到原点的距离dis(X, Y)是从原点到(X, Y)的螺旋折线段的长度。 例如dis(0, 1)3, dis(-2, -1)9 给出整点坐标(X, Y)&#xff0c;你能计算出dis(X, Y)…

JAVA-WEB开发环境和搭建

JAVA Web开发环境与搭建 一、下载安装JDK 1.配置jdk开发环境 JAVA_HOME 2.path 二、下载安装eclipse javaEE版本 三、安装部署tomcat 3.1、安装&#xff1a; 直接解压到指定目录即可。&#xff08;注&#xff1a;目录不要太深&#xff1b;目录不要有中文或空格&#xff09; 3.2…

Vue入门 ---- 简易留言板

##简述 初学vue&#xff0c;比Angular要简单易学一点&#xff0c;基本就是html代码json。这是第一个小的例子&#xff0c;用到了vue的几个常用方法&#xff0c;其中v-for的$index稍微有点迷惑&#xff0c;也影响了完成的速度&#xff0c;网上说是vue2.0已经取消了这种用法&…

Factors of Factorial AtCoder - 2286 (N的阶乘的因子个数)(数论)

Problem Statement You are given an integer N. Find the number of the positive divisors of N!, modulo 10^97. Constraints 1≤N≤10^3Input The input is given from Standard Input in the following format: NOutput Print the number of the positive divisors of N!,…

VS Code编译Python

一、想要编译Python我们首先要安装python&#xff0c;进入官网下载python3&#xff08;不要下载python2.7&#xff0c;不就之后就不会再使用低版本的python了&#xff09; 二、配置环境变量 三、在VS Code中添加插件&#xff0c;记得添加完点击重新加载插件&#xff0c;或…

JAVA学习笔记_五JAVA开发中的WEB前端技术

css 字体属性: font-size font-style font-family font-weight font 设置字体font-family时&#xff0c;中文、英文字体设置时的顺序&#xff0c;英文在前中文在后&#xff1b; font-size&#xff1a;常用单位px&#xff0c;也用in、cm、mm、pt、pc&#xff0c;这几个简…

VS Code编译C/C++

C/C环境的配置要比python的复杂许多&#xff0c;好几个配置文件要写。 一、编译C/C的环境一般都是集成在我们的编辑器中的&#xff0c;如果电脑上有codeblock和dev c的读者可以去安装路径下找找MinGW文件夹&#xff0c;可以不用重复下载。而没有的读者则需要下载MinGW 二、配置…

H5的Video事件,控制方法,及监听

1.标签基本属性 src &#xff1a;视频的属性 poster&#xff1a;视频封面&#xff0c;没有播放时显示的图片preload&#xff1a;预加载autoplay&#xff1a;自动播放loop&#xff1a;循环播放controls&#xff1a;浏览器自带的控制条width&#xff1a;视频宽度 height&#xff…

Hexo+GitHub 快速搭建个人博客(一)---- 基本部署

前期准备&#xff1a; 1.Git shell 2.node.js 3.在github上创建一个仓库&#xff0c;仓库命名格式为xxx.github.io 一、安装Hexo cd进入自己想要安装的目录下&#xff0c;执行下面的命令 npm install hexo-cli -g 升级Hexo npm update hexo -g 卸载Hexo 如果安装过程中…

Gym - 101755G Underpalindromity (树状数组)

Let us call underpalindromity of array b of length k the minimal number of times one need to increment some elements bj by 1 so that the array b would become a palindrome, that is, b1  bk, b2  bk - 1, and so on. The array of length n, consisting of i…

Hexo+GitHub 快速搭建个人博客(二)---- 域名解析

前期准备&#xff1a; 备案的国内域名或者国外域名 &#xff08;后面会解释为什么&#xff0c;这里以阿里云域名为例&#xff09; 一、将个人域名与GitHub博客绑定 我们在Hexo目录下的source子目录内创建一个txt文件&#xff0c;内容写自己的域名&#xff0c;这里可以是一级…

.net core consul 服务配置 服务发现 服务健康检测 服务变更加载

准备环境 安装consul之后 1. 创建一个.net core webapi 举例为UsercenterService 2. nuget引用Consul组件 https://github.com/PlayFab/consuldotnet 3. 创建配置实体类 &#xff08;后面涉及功能介绍时候再解释属性含义&#xff09; 1 public class AppSettings2 {3 …

Hexo+GitHub 快速搭建个人博客(三)---- 改变主题

前期准备&#xff1a; 基本的Linux命令 基本的GitHub命令 Hexo有多种博客框架&#xff0c;在 https://hexo.io/themes/ 里可以找到非常多优秀的博客框架&#xff0c;而且都是免费的。 首先大家可以去找一款自己喜欢的框架&#xff0c;可以选择浏览和直接进入GitHub进行fork …

hdu1814 Peaceful Commission

题目链接&#xff1a;戳我 菜得不行了&#xff0c;直到今天才刚开始学2-SAT。。。。 2-SAT的模板&#xff0c;因为是求最小字典序&#xff0c;所以只能用上限为\(O(nm)\)的最暴力的方法来做。。。 #include<iostream> #include<cstring> #include<cstdio> #i…

Vue入门 ---- 组件式开发

##组件 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><meta http-equiv"X-UA-Compatible" conten…

/usr/bin/python^M: 解释器错误: 没有那个文件或目录

【1】问题现象 执行python脚本&#xff0c;提示错误&#xff1a;/usr/bin/python^M: 解释器错误: 没有那个文件或目录 【2】原因分析 大多数是因为脚本文件在windows下编辑过。在windows下&#xff0c;每一行的结尾是\r\n&#xff0c;而在linux下文件的结尾是\n。 那么&#xf…

Vue入门 ---- 组件通信

##组件通信&#xff1a; 子组件获取父组件的数据父组件获取子组件的数据平行组件之间的通信vue2.0中用子组件修改父组件数据报错问题一定需要通过子组件修改父组件 子组件获取父组件的数据 通过子组件中的属性props&#xff0c;以与父组件数据的绑定。&#xff08;注意&#x…

[51nod1201]整数划分

题目链接&#xff1a; 51nod1201 神仙DP 设\(f[i][j]\)表示\(i\)分成\(j\)个数的划分数&#xff0c;如何转移&#xff1f; 有转移式&#xff1a;\(f[i][j]f[i-j][j-1]f[i-j][j]\) 为什么呢&#xff1f;第一种是先加一个划分出来的数\(1\)&#xff0c;但是为了和之前的所有数不一…

Vue入门 ---- vue-loader 、vue-cli

简介&#xff1a; vue-loader&#xff0c;来源于css-rouder、url-loader、html-loader… 后台node.js–>require exports等都是基于模块的开发 broserify 较早的模块加载器&#xff0c;但是只能加载js webpack&#xff0c;模块加载器&#xff0c;一切东西皆模块&#xff0c;…

Python档案袋( 命令行操作 及 Os与Shutil文件操作补充 )

调用系统命令 import os#调用系统命令&#xff0c;输出只能输出到屏幕上&#xff0c;不能用变量接收 os.system("ipconfig")#调用系统命令&#xff0c;并把执行结果存到变量中 resos.popen("ipconfig").read() print(res) OS模块文件操作 简单的文件和目录…