91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Thinkphp5文件包含漏洞怎么解決

發布時間:2023-02-24 15:00:42 來源:億速云 閱讀:161 作者:iii 欄目:開發技術

這篇文章主要講解了“Thinkphp5文件包含漏洞怎么解決”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Thinkphp5文件包含漏洞怎么解決”吧!

什么是文件包含漏洞

首先我們先了解一下什么是文件包含漏洞,文件包含可以分為本地包含遠程包含,有些時候網站會將文件進行包含來執行,這屬于是常規操作,但若網站并沒有對包含文件進行限制,攻擊者便可以包含一些惡意文件來達到命令執行的效果。這里列出四個常見的PHP包含函數:

Thinkphp5文件包含漏洞怎么解決

漏洞簡述

在該框架中,由于在加載模版解析變量時存在變量覆蓋問題,但像上面所說的一樣沒有對信息進行過濾,從而框架中產生了文件包含漏洞。影響版本如下:

5.0.0 <= Thinkphp <= 5.0.18

5.1.0 <= ThinkPHP <= 5.1.10

漏洞復現

首先我們先搭建一個存在該漏洞的框架版本:

Thinkphp5文件包含漏洞怎么解決

配置好服務后我們開始進行代碼審計,首先先在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函數,后繼續跟進:

Thinkphp5文件包含漏洞怎么解決

我們審計到library/think/View.php下,分析下面的代碼:

Thinkphp5文件包含漏洞怎么解決

里面有一個arrar_merge()函數,我們簡單看一下如何應用:

Thinkphp5文件包含漏洞怎么解決

可以看到該函數起到一個合并數組的作用,賦值后跟進到fetch,直到下面圖片這個位置:

Thinkphp5文件包含漏洞怎么解決

我們這里有一段代碼:

$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函數可以實現變量覆蓋:

Thinkphp5文件包含漏洞怎么解決

而它的規則如下:

Thinkphp5文件包含漏洞怎么解決

若第二個參數值不指定(默認EXTR_OVERWRITE)可能存在變量覆蓋的,覆蓋變量后再進行文件包含惡意文件。這里簡單測試下,我們在public下傳入圖片木馬之后(里面寫入了查詢phpinfo信息的代碼)進行訪問:

public/?cacheFile=1.jpg

成功實現了文件包含:

Thinkphp5文件包含漏洞怎么解決

修復

對于如何修復也是十分簡潔的,get傳參里是否有cachefile鍵,有的話就刪掉,也刪掉_think_cachefile鍵,然后文件包含即可防止該漏洞的產生。

感謝各位的閱讀,以上就是“Thinkphp5文件包含漏洞怎么解決”的內容了,經過本文的學習后,相信大家對Thinkphp5文件包含漏洞怎么解決這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

玉环县| 甘泉县| 柳河县| 北流市| 海淀区| 邯郸市| 锡林浩特市| 太和县| 新密市| 南皮县| 余庆县| 建瓯市| 崇文区| 微山县| 山西省| 乃东县| 成武县| 临夏县| 德兴市| 勐海县| 河曲县| 安阳市| 龙里县| 伊金霍洛旗| 常宁市| 宜章县| 邛崃市| 洪江市| 望城县| 监利县| 团风县| 平度市| 岱山县| 高阳县| 承德市| 长顺县| 四会市| 房山区| 呈贡县| 嘉定区| 乳源|