Thinkphp5文件包含漏洞解析
作者:XINO 发布时间:2023-07-01 19:42:51
前言
ThinkPHP,是为了简化企业级应用开发和敏捷WEB应用开发而诞生的开源轻量级PHP框架。随着框架代码量的增加,一些潜在的威胁也逐渐暴露,本文给大家带来的是对Thinkphp5版本框架里面的文件包含漏洞进行分析,浅谈原理以及如何应用。
什么是文件包含漏洞
首先我们先了解一下什么是文件包含漏洞,文件包含可以分为本地包含和远程包含,有些时候网站会将文件进行包含来执行,这属于是常规操作,但若网站并没有对包含文件进行限制,攻击者便可以包含一些恶意文件来达到命令执行的效果。这里列出四个常见的PHP包含函数:
漏洞简述
在该框架中,由于在加载模版解析变量时存在变量覆盖问题,但像上面所说的一样没有对信息进行过滤,从而框架中产生了文件包含漏洞。影响版本如下:
5.0.0 <= Thinkphp <= 5.0.18
5.1.0 <= ThinkPHP <= 5.1.10
漏洞复现
首先我们先搭建一个存在该漏洞的框架版本:
配置好服务后我们开始进行代码审计,首先先在application/index/controller/Index.php路径下修改代码:
<?php
namespace app\index\controller;
use think\Controller;
class Index extends Controller
{
public function index()
{
$this->assign(request()->get());
return $this->fetch(); // 当前模块/默认视图目录/当前控制器(小写)/当前操作(小写).html
}
}
之后在路径application/index/view/index/ 下创建html模板文件,之后便可以进行分析:
我们根据上面代码:
public function index()
{
$this->assign(request()->get());
return $this->fetch();
}
跟进至assign函数,后继续跟进:
我们审计到library/think/View.php下,分析下面的代码:
里面有一个arrar_merge()函数,我们简单看一下如何应用:
可以看到该函数起到一个合并数组的作用,赋值后跟进到fetch,直到下面图片这个位置:
我们这里有一段代码:
$this->engine->$method($template, $vars, $config);
我们跟进method值在view\driver\Think.php,跟进fetch后再跟进read方法,最后走到了template\driver\File.php,这里有一段代码:
extract($vars, EXTR_OVERWRITE);
同时下面还有一个文件包含函数,因为之前有个vars变量是用户进行get传入的,也就是说变量可控,经过 $this->data 走到了read,而这里面有个extract函数可以实现变量覆盖:
而它的规则如下:
若第二个参数值不指定(默认EXTR_OVERWRITE)可能存在变量覆盖的,覆盖变量后再进行文件包含恶意文件。这里简单测试下,我们在public下传入图片木马之后(里面写入了查询phpinfo信息的代码)进行访问:
public/?cacheFile=1.jpg
成功实现了文件包含:
修复
对于如何修复也是十分简洁的,get传参里是否有cachefile键,有的话就删掉,也删掉_think_cachefile键,然后文件包含即可防止该漏洞的产生。
来源:https://juejin.cn/post/7202231477252784183


猜你喜欢
- 插入一条记录后,如何得到最新的自动增加ID?我们要用到SQL Server的@@IDENTITY。它能够记录下系统最近使用的一个IDENTI
- 本文实例讲述了Python进程的通信Queue、Pipe。分享给大家供大家参考,具体如下:内容相关:概念:进程的通信Queue:创建与使用P
- 这篇文章主要介绍了python3下pygame如何实现显示中文,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,
- 1. 计算给出两个时间之间的时间差import datetime as dt# current timecur_time = dt.date
- Pycharm Database Navigator连接mysql1.安装Database Navigator由于使用的是Pycharm C
- 在讲这个问题之前让我们来先看一段代码: dim sql_injdata,SQL_inj,SQL_Get,SQL_Data,Sql_
- 1、如何放弃正在输入的命令。 在输入一条比较长的命令时,出现打字错误是在所难免的。在这种情况下,放弃正在输入的命令重头再来往往会是更好的选择
- 本文实例讲述了JS实现获取数组中最大值或最小值功能。分享给大家供大家参考,具体如下:方法一://最小值Array.prototype.min
- 如何设置list步长示例:range(a, b, step)>>> list(range(0,5,2)) [0,
- 概述日志文件是MySQL数据库的重要组成部分。MySQL有几种不同的日志文件,通常包括错误日志文件,二进制日志,通用日志,慢查询日志,等等。
- 本文实例讲述了Python实现监控键盘鼠标操作。分享给大家供大家参考,具体如下:# -*- coding: utf-8 -*-import
- 由于 Ubuntu 中的汉字输入实在是太不友好了,所以装了个 搜狗输入法,好不容易把 搜狗输入法装好,本以为可以开开心心的搞代码了,然而。。
- 0.前言回调函数是一种在编程中常见的技术,通常在异步编程中使用。简单来说,回调函数是一个被传递给另一个函数的函数,它在该函数的某个时间点被调
- <html xmlns="http://www.w3.org/1999/xhtml"><head>
- 1、我的源码在 /home/topsec/Documents/php-7.0.11 ,安装位置在 /usr/local/php7, php.
- 分形,具有以非整数维形式充填空间的形态特征。通常被定义为“一个粗糙或零碎的几何形状,可以分成数个部分,且每一部分都(至少近似地)是整体缩小后
- 本文实例为大家分享了小程序实现tab更换页面效果的具体代码,供大家参考,具体内容如下.wxml<scroll-view scroll-
- 目录1、准备基础数据2、一次性展示数据3、引入分页器附:drf分页器的使用1.1 PageNumberPagination1.2 Limit
- 太多程序员没有太多心思去关注他们每天都在面对的编程字体,然后编码工作需要长时间盯着屏幕并阅读一些非常复杂的文本。一个好的字体可以很大程度上提
- 我在网站上设置了邮件列表功能,实现用户自动订阅和发送,但很多用户输入和提交的邮件地址格式都是无效的,无法处理。请问如何解决这一问题?&nbs