Thinkphp5文件包含漏洞解析

 更新时间:2023年02月21日 09:05:32   作者:XINO  
这篇文章主要为大家介绍了Thinkphp5文件包含漏洞解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

前言

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键,然后文件包含即可防止该漏洞的产生。

结语

本文简单讲述了thinkphp5框架中常见的文件包含漏洞及其应用,不知道小伙伴们学会了没有,有兴趣的朋友可以自己手动搭建一个平台来进行渗透测试,更多关于Thinkphp5文件包含漏洞的资料请关注脚本之家其它相关文章!

相关文章

  • Discuz!插件:自动隐藏帖子

    Discuz!插件:自动隐藏帖子

    Discuz!插件:自动隐藏帖子...
    2007-03-03
  • 浅析Yii2中GridView常见操作

    浅析Yii2中GridView常见操作

    本文是小编给大家收集整理些有关网络上Yii2中GridView常见操作中出现的大部分问题,本文做一个总结特此分享到脚本之家平台供大家参考
    2016-04-04
  • PHP获取二维数组中某一列的值集合

    PHP获取二维数组中某一列的值集合

    PHP还是比较常用的,于是我研究了一下PHP二维数组,下面通过本文给大家介绍PHP获取二维数组中某一列的值集合,对php数组二维数组的值相关知识感兴趣的朋友一起学习吧
    2015-12-12
  • 学习PHP Cookie处理函数

    学习PHP Cookie处理函数

    这篇文章主要为大家详细介绍了PHP Cookie处理函数的使用方法,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • laravel中的一些简单实用功能

    laravel中的一些简单实用功能

    这篇文章主要给大家介绍了关于laravel中一些简单实用功能的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • 解决laravel资源加载路径设置的问题

    解决laravel资源加载路径设置的问题

    今天小编就为大家分享一篇解决laravel资源加载路径设置的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • PHPCMS V9 添加二级导航的思路详解

    PHPCMS V9 添加二级导航的思路详解

    这篇文章主要介绍了PHPCMS V9 添加二级导航所遇到些问题,查询导航栏的信息时返回的$r[arrchildid]与自己想象的不符,文档上说是返回子栏目id但是却有些不同。下面小编通过分享本文给大家解答下
    2016-10-10
  • PHP中把对象数组转换成普通数组的方法

    PHP中把对象数组转换成普通数组的方法

    这篇文章主要介绍了PHP中把对象数组转成普通数组的方法,本文直接给出示例代码,需要的朋友可以参考下
    2015-07-07
  • 实例化php类时传参的方法分析

    实例化php类时传参的方法分析

    这篇文章主要介绍了实例化php类时传参的方法,结合实例形式分析了实例化php类时传参的相关原理、实现方法与操作注意事项,需要的朋友可以参考下
    2020-06-06
  • thinkPHP模板算术运算相关函数用法分析

    thinkPHP模板算术运算相关函数用法分析

    这篇文章主要介绍了thinkPHP模板算术运算相关函数用法,结合简单实例形式分析了thinkPHP关于算数运算与参数传递的相关技巧,需要的朋友可以参考下
    2016-07-07

最新评论