php代碼審計(jì)之ThinkPHP5的文件包含漏洞詳解
漏洞影響范圍
加載模版解析變量時(shí)存在變量覆蓋問(wèn)題,導(dǎo)致文件包含漏洞的產(chǎn)生 漏洞影響版本:5.0.0<=ThinkPHP5<=5.0.18 、5.1.0<=ThinkPHP<=5.1.10
我復(fù)現(xiàn)用的是5.1.15
(PS:這里附上thinkphp5.1 手冊(cè)本站下載地址:http://www.dbjr.com.cn/books/729512.html)
環(huán)境配置要將將 application/index/controller/Index.php 文件代碼設(shè)置如下:
<?php
namespace app\index\controller;
use think\Controller;
class Index extends Controller
{
?
? public function index()
? {
?
? ? ? $this->assign(request()->get());
? ? ? return $this->fetch(); // 當(dāng)前模塊/默認(rèn)視圖目錄/當(dāng)前控制器(小寫(xiě))/當(dāng)前操作(小寫(xiě)).html
? }
}創(chuàng)建 application/index/view/index/index.html 文件,內(nèi)容隨意(沒(méi)有這個(gè)模板文件的話,在渲染時(shí)程序會(huì)報(bào)錯(cuò))
漏洞分析
先跟進(jìn)assign方法

再跟進(jìn)

array_merge() 函數(shù)用于把一個(gè)或多個(gè)數(shù)組合并為一個(gè)數(shù)組。
只是賦值操作,跟進(jìn)下面的fetch

繼續(xù)跟進(jìn)

用于$this引用當(dāng)前對(duì)象。用于self引用當(dāng)前類(lèi)。換句話說(shuō), $this->member用于非靜態(tài)成員,self::$member用于靜態(tài)成員。
范圍解析運(yùn)算符(也稱(chēng)為 Paamayim Nekudotayim)或更簡(jiǎn)單的術(shù)語(yǔ)是雙冒號(hào),是一個(gè)允許訪問(wèn)類(lèi)的 靜態(tài)、 常量和重寫(xiě)屬性或方法的標(biāo)記。
fetch 前面的方法 主要是加載模板輸出。這里的method值可以追溯到view\driver\Think.php 視圖引擎

跟入84行fetch進(jìn)入think\templae.php

第200行在讀取的時(shí)候采用了一個(gè)read的方法。繼續(xù)跟進(jìn)read,進(jìn)入template\driver\File.php

危險(xiǎn)危險(xiǎn)危險(xiǎn)??!這里調(diào)用了一個(gè)extract函數(shù),可控變量 $vars 賦值給 $this->data 并最終傳入 File 類(lèi)的 read 方法。而 read 方法中在使用了 extract 函數(shù)后,直接包含了 $cacheFile 變量。這里就是漏洞發(fā)生的關(guān)鍵原因(可以通過(guò) extract 函數(shù),直接覆蓋 $cacheFile 變量,因?yàn)?extract 函數(shù)中的參數(shù) $vars 可以由用戶控制)。

這里extract 該函數(shù)使用數(shù)組鍵名作為變量名, EXTR_OVERWRITE 變量存在則覆蓋
EXTRACT() 函數(shù)用于返回日期/時(shí)間的單獨(dú)部分,比如年、月、日、小時(shí)、分鐘等等。

POC
http://localhost:8000/index/index/index?cacheFile=shell.jpg
圖片馬 shell.jpg 放至 public 目錄下(模擬上傳圖片操作)。
相關(guān)文章
PHP 實(shí)現(xiàn)判斷用戶是否手機(jī)訪問(wèn)
這篇文章主要介紹了PHP 實(shí)現(xiàn)判斷用戶是否手機(jī)訪問(wèn)的方法,十分實(shí)用的功能,推薦給有需要的小伙伴。2015-01-01
php打印一個(gè)邊長(zhǎng)為N的實(shí)心和空心菱型的方法
這篇文章主要介紹了php打印一個(gè)邊長(zhǎng)為N的實(shí)心和空心菱型的方法,實(shí)例分析了php循環(huán)語(yǔ)句繪制圖形的技巧,需要的朋友可以參考下2015-03-03
使用PHP解決http請(qǐng)求超時(shí)的問(wèn)題
當(dāng)進(jìn)行HTTP請(qǐng)求時(shí),有時(shí)候可能會(huì)遇到請(qǐng)求超時(shí)的情況,為了解決這個(gè)問(wèn)題,本文給大家介紹了如何使用PHP解決http請(qǐng)求超時(shí)的問(wèn)題,文中通過(guò)代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12
來(lái)自phpguru得Php Cache類(lèi)源碼
群里也有些朋友對(duì)基礎(chǔ)知識(shí)很不屑,總說(shuō)有能力就可以了,基礎(chǔ)知識(shí)考不出來(lái)什么.對(duì)于這樣的觀點(diǎn),我一直不茍同.2010-04-04
PHP編程中的Session阻塞問(wèn)題與解決方法分析
這篇文章主要介紹了PHP編程中的Session阻塞問(wèn)題與解決方法,簡(jiǎn)單分析了php session阻塞的原理、原因與簡(jiǎn)單解決方法,需要的朋友可以參考下2017-08-08
PHP 配置open_basedir 讓各虛擬站點(diǎn)獨(dú)立運(yùn)行
好幾年前,我在抱怨Apache運(yùn)行PHP的安全性不行,只要一個(gè)站點(diǎn)被人拿下,服務(wù)器上的其他站點(diǎn)就會(huì)跟著遭殃。2009-11-11

