談一談php反序列化(Php反序列化)

本文目錄一覽:

請寫出php變數序列化和反序列化的函數,並舉出1個應用例子

PHP中的序列化和反序列化分別通過函數serialize()和unserialize()即可實現。serialize()的參數可以是resource類型外的所有變數類型,最常見的是用來序列化對象,unseialize()將serialize的返回結果作為參數,進行反序列化,得到原對象。$str = serialize ($obj);…$obj222 = unserialize($str);現在可以用$object222對象來執行該對象可以執行的各種操作。在用serialize序列化對象時,會自動調用__sleep方法,__sleep方法必須返回一個數組,包含需要串列化的屬性。 PHP會拋棄其它屬性的值, 如果沒有__sleep方法,PHP將保存所有屬性,包括private屬性。用unserialize反序列化對象時,PHP 會調用__wakeup方法。__sleep和__wakeup方法可以根據實際需要,都添加上,也可以只要其中的一個,當然也可以都不要。下面給出一個序列化的代碼:共serialize.php和unserialize.php兩個文件。// serialize.php?php

class User

{

private $name;

private $id;

public $sex=”F”;

function __construct()

{

//give user a unique ID 賦予一個不同的ID

$this-id = uniqid();

}

function __sleep()

{

//do not serialize this-id 不串列化id

return(array(“name”,”sex”));

}

function __wakeup()

{

//give user a unique ID

$this-id = uniqid();

}

function p(){

echo “in function p() \t”;

return $this-name;

}

function setname($name){

$this-name = $name;

}

} //create object 建立一個對象

$u = new User;

$u-setname(“pphu”);

//serialize it 串列化

$s = serialize($u);

echo “in serialize.php br/”;

print_r($s);

echo “br/”;

print_r($u);

echo “br/br/”;

? //// unserialize.php?php

include(‘serialize.php’);

//global $s;

$u2 = unserialize($s);

echo “in unserialize.phpbr/”;

echo $u2-p().”br/”;

echo $u2-sex.”br/”;

print_r($u2);

?

這個網站幹什麼的 什麼是PHP反序列化靶機實戰

在我們講PHP反序列化的時候,基本都是圍繞著serialize(),unserialize()這兩個函數。那麼什麼是序列化呢,序列化說通俗點就是把一個對象變成可以傳輸的字元串。舉個例子,不知道大家知不知道json格式,這就是一種序列化,有可能就是通過array序列化而來的。而反序列化就是把那串可以傳輸的字元串再變回對象。而反序列化則比較容易出現漏洞。

這麼序列化一下然後反序列化,為什麼就能產生漏洞了呢?

這個時候,我們就要了解一下PHP裡面的魔術方法了,魔法函數一般是以__開頭,通常會因為某些條件而觸發不用我們手動調用:

在研究反序列化漏洞的時候,如果伺服器能夠接收我們反序列化過的字元串、並且未經過濾的把其中的變數直接放進這些魔術方法裡面的話,就容易造成很嚴重的漏洞了。

所以這個網站其實希望告訴大家這個反序列化的問題,並提供一些實戰練習。

thinkphp 反序列化有什麼用

ThinkPHP系統變數,常量,序列化,反序列化,緩存

變數的輸出:

在模板中輸出一個變數有兩種形式:{$list.name} {$list[『name』]}

在模板中可以使用系統變數,以$Think.開頭

系統變數:(舉例選幾個)

獲得伺服器的IP地址:{$Think.server.SERVER_ADDR}

獲得外部訪問的IP地址:{$Think.server.REMOTE_ADDR}

獲得伺服器的名稱:{$Think.server.SERVER_NAME}

獲得ThinkPHP內部定義的變數:

獲得當前的時間:{$Think.now}

獲得當前工具的版本:{$Think.version}

模板的頁面:{$Think.template}

模板標籤起始符號:{$Think.LDELIM }

模板標籤結束符號:{$Think.RDELIM }

系統常量:(舉例選幾個)

獲得當前文件的url :{$Think.const.__SELF__}

獲得模板配置文件的配置項的值:

{$Think.config.db_name}

在ThinkPHP模板中,對變數使用函數調節:

從控制器分配了一個字元串,在模板中,如何截取這個字元串:{$str|substr=###,5,3} 如果當前參數為函數的第一個參數,可以不寫###

在模板中載入外部文件:

使用include file=」」 file( )和display( )的用法一樣。

If標籤的使用:if condition=」條件1」value1elseifcondition=」條件2」value2else/value3/if   condition裡面寫成比較運算符  eq表示等於 neq表示不等於

修改模板引擎的界定符:

在配置文件中,通過TMPL_L_DELIM修改

『TMPL_L_DELIM』=』{』  //修改左定界符

『TMPL_R_DELIM』=』{』  //修改右定界符

修改模板引擎:

‘TMPL_ENGINE_TYPE’=’Smarty’

在分組中添加配置文件,在控制器中使用直接調用C函數。

ThinkPHP的緩存機制:

數據緩存:就是講資料庫中獲得的數據保存在一個介質上,需要時直接在這個介質上讀取。

我們需要通過ThinkPHP中的cache類來實現,通過這個類的方法獲得對象,在通過這個對象來實現不同介質的數據處理。

通過傳遞不同的參數獲得不通過的數據處理對象。

$cache=Cache::getInstance(『File』);

頁面緩存:

1.    開啟緩存

在配置文件中開啟緩存,開啟緩存有一定的規則(數組格式)。

『HTML_CACHE_ON』= true,

『HTML_CACHE_RULES』=array(

//需要緩存的動作名=緩存的名稱,緩存的生存周期

『show』=array(『{:module}_{:action}』,1000),

)

{:module}代表當前的控制器名

{:action}代表當前的動作名(例如:show)

{$_GET}={$Think.get.id} 簡寫形式{$_get}

通過地址欄傳遞一個id參數,可以實現單頁面多緩存

(通常是前台有緩存,後台不緩存)

局部不緩存:

在TP框架中,局部不緩存可以通過js , ajax , jQuery實現局部不緩存

scripttype=”text/JavaScript”

var date=Date();

document.write(date);

/script

工廠模式:通過傳遞不同參數獲得不同的對象

單例模式:這個類只獲得一個對象,再調用這個對象方法

緩存的增刪改查

增:$cache-set(『password』,』123』,30) 第三個參數是緩存的有效期

刪:rm( ) 改:set( ) 查:get( )

序列化(  serialize( ) ):保存數據的時候,將數組或者對象序列化成字元串,但是這個字元串保存了數組或者對象之前的結構和內容,當我們需要獲得這個數據的時候,在將序列化的字元串反序列化成我們需要的數組或對象(unserialize( ))

例子:

public functionxv(){

//序列化與反序列化

$a=array(‘name’=’xiaoming’);

$x=serialize($a);

echo $x; //輸出結果為:a:1:{s:4:”name”;s:8:”xiaoming”;}

echo “br/”;

$f=unserialize($x);

print_r($f);//輸出原來的數組格式

}

php如何循環反序列化?

1.構造HITCON類反序列化字元串,其中$method=’login’,$args數組』username』部分可用於構造SQL語句,進行SQL注入,’password』部分任意設置。

2.調用login()函數後,利用username構造聯合查詢,使查詢結果為SoFun類反序列化字元串,設置username構造聯合查詢,使查詢結果為SoFun類反序列化字元串,設置username構造聯合查詢,使查詢結果為SoFun類反序列化字元串,設置file=『flag.php』,需繞過__wakeup()函數。

3.繞過oadData()函數對反序列化字元串的驗證。

4.SoFun類 __destruct()函數調用後,包含flag.php文件,獲取flag,需繞過__wakeup()函數。

php中序列化與反序列化

把複雜的數據類型壓縮到一個字元串中

serialize() 把變數和它們的值編碼成文本形式

unserialize() 恢復原先變數

eg:

結果:a:3:{i:0;s:3:”Moe”;i:1;s:5:”Larry”;i:2;s:5:”Curly”;}

Array ( [0] = Moe [1] = Larry [2] = Curly )

當把這些序列化的數據放在URL中在頁面之間會傳遞時,需要對這些數據調用urlencode(),以確保在其中的URL元字元進行處理:

margic_quotes_gpc和magic_quotes_runtime配置項的設置會影響傳遞到unserialize()中的數據。

如果magic_quotes_gpc項是啟用的,那麼在URL、POST變數以及cookies中傳遞的數據在反序列化之前必須用stripslashes()進行處理:

如果magic_quotes_runtime是啟用的,那麼在向文件中寫入序列化的數據之前必須用addslashes()進行處理,而在讀取它們之前則必須用stripslashes()進行處理:

當對一個對象進行反序列化操作時,PHP會自動地調用其__wakeUp()方法。這樣就使得對象能夠重新建立起序列化時未能保留的各種狀態。例如:資料庫連接等。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/285600.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-22 15:45
下一篇 2024-12-22 15:45

相關推薦

  • 金額選擇性序列化

    本文將從多個方面對金額選擇性序列化進行詳細闡述,包括其定義、使用場景、實現方法等。 一、定義 金額選擇性序列化指根據傳入的金額值,選擇是否進行序列化,以達到減少數據傳輸的目的。在實…

    編程 2025-04-29
  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • 理解Java反序列化(Java Deserialization Vulnerability)

    本文將從多個方面深入探討Java反序列化漏洞,對於筆者所總結的經驗和教訓,以及掌握Java反序列化的設計模式、最佳實踐和防範措施。 一、Java反序列化漏洞概述 Java反序列化漏…

    編程 2025-04-28
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    編程 2025-04-28
  • PHP獲取301跳轉後的地址

    本文將為大家介紹如何使用PHP獲取301跳轉後的地址。301重定向是什麼呢?當我們訪問一個網頁A,但是它已經被遷移到了另一個地址B,此時若伺服器端做了301重定向,那麼你的瀏覽器在…

    編程 2025-04-27
  • PHP登錄頁面代碼實現

    本文將從多個方面詳細闡述如何使用PHP編寫一個簡單的登錄頁面。 1. PHP登錄頁面基本架構 在PHP登錄頁面中,需要包含HTML表單,用戶在表單中輸入賬號密碼等信息,提交表單後服…

    編程 2025-04-27
  • PHP與Python的比較

    本文將會對PHP與Python進行比較和對比分析,包括語法特性、優缺點等方面。幫助讀者更好地理解和使用這兩種語言。 一、語法特性 PHP語法特性: <?php // 簡單的P…

    編程 2025-04-27
  • PHP版本管理工具phpenv詳解

    在PHP項目開發過程中,我們可能需要用到不同版本的PHP環境來試驗不同的功能或避免不同版本的兼容性問題。或者我們需要在同一台伺服器上同時運行多個不同版本的PHP語言。但是每次手動安…

    編程 2025-04-24
  • PHP數組去重詳解

    一、array_unique函數 array_unique是php中常用的數組去重函數,它基於值來判斷元素是否重複,具體使用方法如下: $array = array(‘a’, ‘b…

    編程 2025-04-24

發表回復

登錄後才能評論