php內置類反序列化,php反序列化字符逃逸

本文目錄一覽:

到底什麼是PHP序列化?

在PHP中,序列化用於存儲或傳遞 PHP 的值的過程中,同時不丟失其類型和結構。本文講述PHP序列化的四種方案,感興趣的可以了解一下

序列化是將變量轉換為可保存或傳輸的字符串的過程;反序列化就是在適當的時候把這個字符串再轉化成原來的變量使用。這兩個過程結合起來,可以輕鬆地存儲和傳輸數據,使程序更具維護性。

1、什麼是PHP序列化——serialize和unserialize函數

這兩個是序列化和反序列化PHP中數據的常用函數。

$a = array(‘a’ = ‘Apple’ ,’b’ = ‘banana’ , ‘c’ = ‘Coconut’);

//序列化數組$s = serialize($a);echo $s;//輸出結果:a:3:{s:1:”a”;s:5:”Apple”;s:1:”b”;s:6:”banana”;s:1:”c”;s:7:”Coconut”;}

echo ”

;

//反序列化$o = unserialize($s);

print_r($o);

當數組值包含如雙引號、單引號或冒號等字符時,它們被反序列化後,可能會出現問題。為了克服這個問題,一個巧妙的技巧是使用base64_encode和base64_decode。

$obj = array();//序列化$s = base64_encode(serialize($obj)); //反序列化$original = unserialize(base64_decode($s));

但是base64編碼將增加字符串的長度。為了克服這個問題,可以和gzcompress一起使用。

//定義一個用來序列化對象的函數

function my_serialize( $obj ) { return base64_encode(gzcompress(serialize($obj))); }

//反序列化function my_unserialize($txt) { return unserialize(gzuncompress(base64_decode($txt))); }

2、什麼是PHP序列化——json_encode 和 json_decode

使用JSON格式序列化和反序列化是一個不錯的選擇:

使用json_encode和json_decode格式輸出要serialize和unserialize格式快得多。

JSON格式是可讀的。

JSON格式比serialize返回數據結果小。

JSON格式是開放的、可移植的。其他語言也可以使用它。

$a = array(‘a’ = ‘Apple’ ,’b’ = ‘banana’ , ‘c’ = ‘Coconut’);

//序列化數組$s = json_encode($a);echo $s;//輸出結果:{“a”:”Apple”,”b”:”banana”,”c”:”Coconut”}

echo ‘

;

//反序列化$o = json_decode($s);

在上面的例子中,json_encode輸出長度比上個例子中serialize輸出長度顯然要短。[page]

3、什麼是PHP序列化——var_export 和 eval

var_export 函數把變量作為一個字符串輸出;eval把字符串當成PHP代碼來執行,反序列化得到最初變量的內容。

$a = array(‘a’ = ‘Apple’ ,’b’ = ‘banana’ , ‘c’ = ‘Coconut’);

//序列化數組$s = var_export($a , true);echo $s;//輸出結果: array ( ‘a’ = ‘Apple’, ‘b’ = ‘banana’, ‘c’ = ‘Coconut’, )

echo ‘

‘;

//反序列化eval(‘$my_var=’ . $s . ‘;’);

print_r($my_var);

4、什麼是PHP序列化——wddx_serialize_value 和 wddx deserialize

wddx_serialize_value函數可以序列化數組變量,並以XML字符串形式輸出。

$a = array(‘a’ = ‘Apple’ ,’b’ = ‘banana’ , ‘c’ = ‘Coconut’);

//序列化數組$s = wddx_serialize_value($a);echo $s;

//輸出結果(查看輸出字符串的源碼): ApplebananaCoconut

echo ‘

‘;

//反序列化$o = wddx_deserialize($s);

print_r($o);//輸出結果:Array ( [a] = Apple [b] = banana 1 = Coconut )

可以看出,XML標籤字符較多,導致這種格式的序列化還是佔了很多空間。

結論

上述所有的函數在序列化數組變量時都能正常執行,但運用到對象就不同了。例如json_encode序列化對象就會失敗。反序列化對象時,unserialize和eval將有不同的效果。

本篇《什麼是PHP序列化?這個知識點才是你應該了解到的用》到這裡就已經結束了,小編一直認為,某一個編程軟件受歡迎是有一定原因的,首先吸引人的一定是其功能,環球網校的小編祝您PHP學習之路順利,如果你還想知道更多php知識,也可以點擊本站的其他文章進行學習。

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

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

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

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

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

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

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的序列化和反序列化有什麼好處

序列化是將變量轉換為可保存或傳輸的字符串的過程;反序列化就是在適當的時候把這個字符串再轉化成原來的變量使用。這兩個過程結合起來,可以輕鬆地存儲和傳輸數據,使程序更具維護性。

PHP中的序列化和反序列化分別通過函數serialize()和unserialize()即可實現。serialize()的參數可以是resource類型外的所有變量類型,最常見的是用來序列化對象,unseialize()將serialize的返回結果作為參數,進行反序列化,得到原對象。

在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中序列化與反序列化

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

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-hant/n/288785.html

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

相關推薦

  • 金額選擇性序列化

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

    編程 2025-04-29
  • 英語年齡用連字符號(Hyphenation for English Age)

    英語年齡通常使用連字符號表示,比如 “five-year-old boy”。本文將從多個方面探討英語年齡的連字符使用問題。 一、英語年齡的表達方式 英語中表…

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

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

    編程 2025-04-29
  • Python字符轉列表指南

    Python是一個極為流行的腳本語言,在數據處理、數據分析、人工智能等領域廣泛應用。在很多場景下需要將字符串轉換為列表,以便於操作和處理,本篇文章將從多個方面對Python字符轉列…

    編程 2025-04-29
  • Python學習筆記:去除字符串最後一個字符的方法

    本文將從多個方面詳細闡述如何通過Python去除字符串最後一個字符,包括使用切片、pop()、刪除、替換等方法來實現。 一、字符串切片 在Python中,可以通過字符串切片的方式來…

    編程 2025-04-29
  • Python計算中文字符個數

    本文將從多個方面對Python計算中文字符個數進行詳細的闡述,包括字符串長度計算、正則表達式統計和模塊使用方法等內容。 一、字符串長度計算 在Python中,計算字符串長度是非常容…

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

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

    編程 2025-04-29
  • Python中如何判斷字符為數字

    判斷字符是否為數字是Python編程中常見的需求,本文將從多個方面詳細闡述如何使用Python進行字符判斷。 一、isdigit()函數判斷字符是否為數字 Python中可以使用i…

    編程 2025-04-29
  • Python中逗號算字符嗎

    Python中逗號既可以作為分隔符,也可以作為一個表達式中的運算符。關於逗號作為分隔符是不會被算作字符的事情,這點大家都知道。本文主要就是闡述逗號作為運算符在表達式中是會被算作字符…

    編程 2025-04-28
  • 從16進制轉義到中文字符

    16進制轉義是為了在不同的字符集、不同的編碼下,能夠保證特殊字符被正確的識別和渲染。本文將從多個方面對16進制轉義做詳細的闡述,讓讀者對其有更深入的了解。 一、轉義實現 在Web開…

    編程 2025-04-28

發表回復

登錄後才能評論