CVE-2018-7600 Drupal核心遠程代碼執行漏洞分析

来源:https://www.cnblogs.com/Ivan1ee/archive/2018/12/27/10187131.html
-Advertisement-
Play Games

0x01 漏洞介紹 Drupal是一個開源內容管理系統(CMS),全球超過100萬個網站(包括政府,電子零售,企業組織,金融機構等)使用。兩周前,Drupal安全團隊披露了一個非常關鍵的漏洞,編號CVE-2018-7600 Drupal對錶單請求內容未做嚴格過濾,因此,這使得攻擊者可能將惡意註入表單 ...


 

 

0x01 漏洞介紹

Drupal是一個開源內容管理系統(CMS),全球超過100萬個網站(包括政府,電子零售,企業組織,金融機構等)使用。兩周前,Drupal安全團隊披露了一個非常關鍵的漏洞,編號CVE-2018-7600 Drupal對錶單請求內容未做嚴格過濾,因此,這使得攻擊者可能將惡意註入表單內容,此漏洞允許未經身份驗證的攻擊者在預設或常見的Drupal安裝上執行遠程代碼執行。

0x02 漏洞分析

Drupal渲染數組的情況有頁面載入和Ajax表單發出的請求,在這裡Ajax API調用是攻擊者最佳的選擇。那麼作為用戶註冊表單的一部分,圖片欄位使用Ajax API將圖片上傳到伺服器,並且生成縮略圖

 

 

查閱了相關文檔資料現在,我們所要做的就是註入一個惡意渲染數組,該數組使用Drupal的渲染回調方法在系統上執行代碼。有幾個屬性我們可以註入:

 

#access_callback 標簽雖然callback回調函數可控,但需要回調處理的字元串不可控,導致無法利用。以下場景以post_render和lazy_builder為例

2.1、漏洞場景1:引入#post_render

#post_render

這個API標簽可以被所有的元素和表單使用,它是在drupal_render()方法中調用,可以渲染當前元素和子元素,也可對內容進行修改。

例子中$ element通過調用admin_form_html_cleanup函數處理返回處理後的結果。再來看可以觸發攻擊載荷的代碼,在渲染的過程中調用了call_user_func進行回調處理,但$callable 回調函數通過表單偽造,$elements的子元素同樣也是通過表單可控

攻擊者利用攻擊載荷 mail[#post_render][]=passthru&mail[#type]=markup&mail[#markup]=whoami ,這裡的#markup是當前元素#type的子元素,通過數組的方式傳入值,執行過程如圖

魔術方法__toString得到$this->string 等於whoami ,帶入到call_user_func中交給passthru函數執行,導致漏洞觸發

PHP內置函數pasthru執行後會回顯結果

2.2、漏洞場景2:引入#lazy_builder

#lazy_builder 可選,數組值,必須有且只有兩個元素,一個是回調函數名,一個回調的參數,參數只能是NULL或者標量類型

$callable變數取#lazy_builder元素標簽數組下標0的值作為回調函數名,取數組下標1的值當回調方法的參數, 下麵攻擊載荷調用PowerShell 遠程下載文件到本地保存為php網頁後門,代碼如下圖

 

我們傳入的lazy_builder[0]和lazy_builder[1]的值在渲染的時候用call_user_func_array完成整個攻擊過程

整個漏洞的產生過程都是因為call_user_func或者call_user_func_array等回調函數導致的任意代碼執行,API元素標簽中可能還會觸發漏洞的標簽有#theme 、#create_placeholder、#theme_wrappers等等。

0x04 緩解措施

官方在最新版本8.5.1中增加了下圖方法

對請求的GET、POST、COOKIE 進行過濾處理

希望廣大用戶儘快升級到最新版本Drupal 8.5.1 , 下載地址:https://www.drupal.org/project/drupal/releases/8.5.1

 

0x05 Reference

https://research.checkpoint.com/uncovering-drupalgeddon-2/

https://github.com/g0rx/CVE-2018-7600-Drupal-RCE/blob/master/exploit.py

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天優化了一下三級菜單的代碼 兩個版本: 一:分幾次迴圈完成: ...
  • Models.py#coding:utf8fromflaskimportFlaskfromflask_sqlalchemyimportSQLAlchemyapp=Flask(__name__)#實例化app.config["SQLALCHEMY_DATABASE_URI"]="mysql://roo... ...
  • 源碼文件的三種類型: 命令源文件:可以直接運行的程式,可以不編譯而使用命令“go run”啟動、執行。 庫源碼文件 測試源碼文件 面試題:命令源碼文件的用途是什麼,怎樣編寫它? 典型回答: 命令源碼文件是程式的運行入口,是每個可獨立運行的程式必須擁有的。 我們可以通過構建或安裝生成與其對應的可執行文 ...
  • 二叉樹首先要解決構建問題,才能考慮後續的遍歷,這裡貼出通過先序構建二叉樹,同時包含四種二叉樹的遍歷方法(先序,中序,後序,逐層) 第一、定義BinaryTreeNode 類 1 #include <iostream> 2 #include <string> 3 #include <queue> 4 ...
  • 1. 初識面向對象 面向過程: 一切以事務的發展流程為中心. 面向對象: 一切以對象為中心. 一切皆為對象. 具體的某一個事務就是對象 打比方: 大象進冰箱 步驟: 第一步, 開門, 第二步, 裝大象, 第三步, 關門 面向對象:大象, 你進冰箱. 此時主語是大象. 我操縱的是大象. 此時的大象就是 ...
  • 下麵給出這道一臉不可做的題的鬼畜性質: 1)對於一個點來說,其歸屬狀態是確定的:走不到、A黨或B黨 。(黑白格染色) 方便起見,將包含所有不可達的點的極小矩形向外擴展一圈,設為矩形M。 2)矩形M的最外圈上相鄰兩點點到(0,0)的最短曼哈頓距離差值不超過1。 3)矩形M外任意正對於矩形M的點到垂直走 ...
  • 1.namedtuple 命名元組 -> 類似創建一個類 from collections import namedtuple # 類 p = namedtuple("Point", ["x", "y","z"]) # 對象 p1 = p(10, 20,30) print(p1) print(p1. ...
  • 2018-12-27 元組的操作方法(tuple) 1.列表是有序的;元素可以被修改 元組也是有序的,但是其一級元素不可被修改,不能被增加或刪除,在創建元組時,可在最後一個元素後加逗號以區分元組和方法 (1212,"asnfuih",[2131,"safg"],) 2.可用索引和切片取值,也可用fo ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...