php反序列化學習(1)

1、php面向對象基本概念

類的定義:

類是定義了一件事物的抽象特征,它將數據的形式以及這些數據上的操作封裝住在一起。(對象是具有類類型的變量,是對類的實例)

構成:

成員變量(屬性)+成員函數(方法)

成員變量的值對外不可見,需要通過成員函數訪問。

2、類與對象

實例化和賦值:再給實例化進行賦值的時候要首先確保類里面定義過這個屬性

類的修飾符介紹
在類中直接聲明的變量稱為成員屬性(也可以成為成員變量)。
可以在類中聲明多個變量,即“對象”中可以有多個成員屬性,每個變量都存儲"對象’不同的屬性信息。
常用訪問權限修飾符:(對屬性的定義)
public:公共的,在類的內部、子類中或者類的外部都可以使
用,不受限制;
protected:受保護的,在類的內部、子類中可以使用,但不能
在類的外部使用;
private:私有的,只能在類的內部使用,在類的外部或者子類中
都無法使用。

類與對象的關系

類是對象的抽象,而對象是類的具體實例。
類是想法,把類實例化(new),調用具體值后就變成了對象。
類的成員方法:
在類中定義的函數被稱為成員方法。函數實現的是某個獨立的功能;
成員方法實現的是類中的一個行為,是類的一部分。
可以在類中聲明多個成員方法,成員方法的聲明和函數聲明完全一樣,只
不過在聲明成員方法時可以在function關鍵字前加一些訪問權限修飾符,
如public、protected、private(可以省略,默認為public)

3、序列化

對象的序列化:不能序列化‘類’,可以序列化‘對象’,只序列化成員變量不序列化成員函數

private私有屬性序列化時在變量前加空格(就是url編碼中的%00類名%00)

protected受保護屬性序列化時在變量名前加%00*%00

4、反序列化特性

1、反序列化之后的內容為一個對象

2、反序列化生成的對象里的值,又反序列化里的值提供,與原有類預定定義的值無關。

3、反序列化不觸發類的成員方法;需要調用方法后才能觸發

5、反序列化漏洞

簡單例題:

首先定義了一個test類,其中有成員變量a和成員方法(調用displayvar)并輸出,通過get傳入benben,并將其反序列化后復制再次調用displayvar。因此可以利用get傳入的參數來完成所需要的指令。如果要執行system(‘ls’)指令,就需要將其寫為序列化的形式通過get上傳。

payload:

?benben=o:4:"test":1:{s:1:"a";s:13:"system('id');";}

6、魔術方法

定義:

一個預定好的,在特定情況下自動觸發的行為方法

作用:

特定條件下自動調用相關方法,達到觸發代碼

實例:

_construct():構造函數,在實例化一個對象時,首先會去自動化執行的方法

觸發時機:實例化對象

功能:提前清理不必要的內容

_destruct():析構函數,在對象的所有引用被刪除或者當對象被顯式銷毀時執行的魔術方法。(實例化對象結束后會被銷毀,也會觸發析構函數)

_sleep():序列化serialize()函數會檢查類中是否存在一個魔術方法_sleep()如果存在,該方法會先被調用,然后才執行序列化操作。

觸發時機:序列化serialize()之前

將benben的值傳給cmd,然后對user進行實例化,此時觸發_construct(),對user進行序列化觸發_sleep(),因此想要通過命令執行獲得信息就可以在benben中傳入任意命令進行執行。

_wakeup():unserialize()會檢查是否存在一個_wakeup()方法,如果存在,則會先調用_wakeup()方法,預先準備對象需要的資源。

觸發時機:unserialize()反序列化之前

_wakeup():在反序列化unserialize()之前

_destruct():在反序列化unserialize()之后

_toString():表達方式錯誤導致魔術方法觸發

觸發時機:把對象當成字符串調用

_invoke():格式表達錯誤導致魔術方法觸發

觸發時機:把對象當成函數調用

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

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

相關文章

基于開源項目HAL STM32F4 +DSP庫跑SVPWM開環速度測試

HAL STM32F4 ARM DSP庫跑SVPWM開環速度測試 ?本篇硬件電路和代碼來源于此開源項目:https://github.com/MengYang-x/STM3F401-FOC/tree/main📍硬件電路和項目介紹,立創開源廣場:https://oshwhub.com/shadow27/tai-yang-neng-wu-re…

走進智慧倉儲:3D可視化工廠園區革新物流新紀元

在快節奏的現代生活中,物流倉儲行業扮演著至關重要的角色。隨著科技的飛速發展,傳統倉儲模式正面臨一場前所未有的變革。今天,就讓我們一起看看3D可視化技術如何為物流行業帶來前所未有的便利與效率。 什么是3D可視化工廠園區? 3…

2024華為OD機試真題-最長子字符串的長度(一)-C++-OD統一考試(C卷D卷)

題目描述 給你一個字符串 s,首尾相連成一個環形,請你在環中找出 o 字符出現了偶數次最長子字符串的長度。 輸入描述 輸入是一個小寫字母組成的字符串 輸出描述 輸出是一個整數 備注 1 ≤ s.length ≤ 500000 s 只包含小寫英文字母 用例1 輸入 alol…

vim常用指令——001

vim常用指令 Vim的命令模式常用操作一、定位移動光標二、行的基本操作【復制、粘貼、刪除】三、查找、替換四、分屏命令 總結給大家總結下四個運行模式: Vim的命令模式常用操作 一、定位移動光標 按h:將光標向左移動一個字符,等同于方向鍵左…

UI學習筆記(二)—— 深入了解導航控制

「OC」UI學習筆記&#xff08;二&#xff09; 文章目錄 「OC」UI學習筆記&#xff08;二&#xff09;手動布局子視圖自動布局子視圖導航控制器高級使用 手動布局子視圖 //父視圖的.h文件 #import <UIKit/UIKit.h> NS_ASSUME_NONNULL_BEGINinterface JCSuperView : UIVie…

【最新區塊鏈論文錄用資訊】CCF A—INFOCOM 2024 共17篇

Conference&#xff1a;IEEE International Conference on Computer Communications CCF level&#xff1a;CCF A Categories&#xff1a;計算機網絡 Year&#xff1a;2024 Num&#xff1a;17 A Generic Blockchain-based Steganography Framework with High Capacity via …

Python: 使用pyotp實現OTP一次性密碼驗證

使用pyotp實現OTP一次性密碼驗證 OTP的基本原理 生成一個共享秘鑰作為隨機數的種子服務端通過種子計算出當前的密碼客戶端也通過相同的種子計算出當前的密碼驗證客戶端生成的密碼和服務端生成的密碼是否匹配 服務端和客戶端計算的方式一樣 共享密鑰 時間因子 算法 > 密…

多個文本如何一鍵導出二維碼?在線批量生碼的制作方法

當存在多條文本數據并且需要將每條數據生成單獨的二維碼來使用&#xff0c;很多小伙伴可能還在用一個一個來制作的方法&#xff0c;在二維碼生成器上將文本轉二維碼。這種方式操作起來比較的繁瑣&#xff0c;需要浪費大量的時間&#xff0c;那么有什么方法可以簡化這個過程嗎&a…

【Android-Compose】ViewModel 的 init 初始化函數中使用非主線程上的協程閃退問題

問題&#xff1a; 在 Compose- kotlin 中&#xff0c;如果在 ViewModel 中的 init 函數中使用非主線程上的協程會導致閃退問題&#xff0c; 具體代碼為&#xff1a; HiltViewModel class ApkScreenViewModel Inject constructor(... ) : ViewModel() {// 1. 在非 主線程的協程…

#學習方法#筆記#微信

飛鳥寫作是一個非常好用、靠譜且方便的論文寫作工具&#xff0c;可以幫助用戶高效地完成論文寫作任務。無論是學生還是研究人員&#xff0c;使用飛鳥寫作都能極大地提升寫作效率和質量。 首先&#xff0c;飛鳥寫作具有強大的查重降重功能&#xff0c;能夠幫助用戶快速檢測論文…

【數據庫】數據庫學習(MySQL,Oracle,PostgreSql)

數據庫語句學習 摘要&#xff1a;文章主要內容是數據庫語句的基本操作&#xff0c;以及一些基本的數據庫標準庫函數 重點&#xff1a;SQL語句對大小寫不敏感 數據庫操作語句 SELECT - 從數據庫表中獲取數據UPDATE - 更新數據庫表中的數據DELETE - 從數據庫表中刪除數據INSERT …

OSPF的擴展配置

1、認證——直連的鄰居或鄰接關系間,進行認證配置后,5種數據包中均攜帶身份核實的密碼&#xff0c;且華為設備會對更新信息進行加密--前提為認證方式選擇密文認證 1)接口認證 [r1-GigabitEthernet0/0/1ospf authentication-mode md5 1 cipher 123456 直連的鄰居間秘鑰和編號、模…

行列視(RCV)能否同時支持多個實時數據庫?

行列視&#xff08;RCV&#xff09;生產數據應用系統在設計時考慮到了多數據源的需求&#xff0c;因此它支持同時連接多個實時數據庫。這意味著用戶可以輕松地將來自不同實時數據庫的數據整合到行列視&#xff08;RCV&#xff09;系統中&#xff0c;實現數據的集中管理和分析。…

Android14 WMS-窗口添加流程(二)-Server端

上一篇文章講到了Client端窗口添加流程&#xff0c;本文接著上文往下講&#xff0c;講一下Server端的窗口添加流程。 1. WindowManagerService#grantInputChannel 由grantInputChannel我們可以看到&#xff0c;Client端傳入了session對象&#xff0c; 發起者Uid-callingUid&am…

X.509數字證書

在國密標準文件《GMT 0015-2012 基于SM2密碼算法的數字證書格式》里有對X.509數字證書格式的詳細描述。 數字證書的定義 由國家認可的&#xff0c;具有權威性、可信性和公正性的第三方證書認證機構&#xff08;CA&#xff09;進行數字簽名的一個可信的數字化文件。 數字證書…

YOLOv10代碼詳細介紹(附錄訓練教程和權重)

前言 YOLOv10 是清華大學研究人員在 UltralyticsPython 清華大學的研究人員在 YOLOv10軟件包的基礎上&#xff0c;引入了一種新的實時目標檢測方法&#xff0c;解決了YOLO 以前版本在后處理和模型架構方面的不足。通過消除非最大抑制&#xff08;NMS&#xff09;和優化各種模型…

【幾何角度】感知機

本質&#xff1a;將n維空間中的一些點線性投影到一維&#xff0c;在一維軸上找一個閾值對這些點進行二分類。 程序&#xff1a; import numpy as npclass Perceptron:def __init__(self, learning_rate0.01, n_iterations1000):self.learning_rate learning_rateself.n_itera…

【Python基礎】一文搞懂:Python 中 “requirements.txt“ 文件生成和使用

文章目錄 1 引言2 什么是 requirements.txt&#xff1f;3 如何生成 requirements.txt&#xff1f;3.1 方法一&#xff1a;使用 pip freeze3.2 方法二&#xff1a;使用 pipreqs 3.3 使用 pip freeze 和 pipreqs 的對比4 如何使用 requirements.txt&#xff1f;4.1 安裝依賴4.2 更…

[從零開發JS應用] 如何在VScode中配置Javascript環境,常見的調試方法有哪些?

一、安裝VSCode和Node.js 記錄環境配置&#xff1a;本文配置的環境主要針對單獨JS文件的斷點調試&#xff0c;主要是為了調試LeetCode里面的代碼。 首先在官網下載對應的版本&#xff1a;https://nodejs.org/en/ 開始安裝&#xff0c;可以自定義選擇安裝路徑。 這里選擇Add Pa…

【親測,安卓版】快速將網頁網址打包成安卓app,一鍵將網頁打包成app,免安裝純綠色版本,快速將網頁網址打包成安卓apk

背景&#xff1a;部分客戶需求將自己網站打包成app&#xff0c;供用戶在瀏覽器安裝使用、 網頁網址快速生成app 準備材料操作流程第一步&#xff1a;打開HBuilder X新建項目第二步創建Wap2App項目第三步修改App圖標第四步發布app第五步查看apk 準備材料 1.需要打包的網頁 2.ap…