本文實例講述了PHP中SERIALIZE和JSON的序列化與反序列化操作區(qū)別。分享給大家供大家參考,具體如下:
PHP中SERIALIZE和JSON序列化與反序列化區(qū)別是什么呢,對于這個問題我們可以和小編一起來看看,具體的操作細節(jié)如下所示。
在PHP中,serialize和json兩種方式對一個對象或數(shù)組進行序列化或反序列化有什么區(qū)別呢?
假設一個對象和一個數(shù)組:
$web = new stdClass;$web->site = 'tantengvip';$web->owner = 'tuntun';$web->age = 5;//和$web = array();$web['site'] = 'tantengvip';$web['owner'] = 'tuntun';$web['age'] = 5;
對它們分別用serialize函數(shù)和unserialize函數(shù)進行序列化和反序列化,看看打印結(jié)果分別是什么,如下:
使用serialize方式:
var_dump(serialize($web));var_dump(unserialize(serialize($web)));var_dump(json_encode($web));var_dump(json_decode(json_encode($web)));
結(jié)果:
string 'O:8:"stdClass":3:{s:4:"site";s:10:"tantengvip";s:5:"owner";s:6:"tuntun";s:3:"age";i:5;}' (length=87)object(stdClass)[127] public 'site' => string 'tantengvip' (length=10) public 'owner' => string 'tuntun' (length=6) public 'age' => int 5string '{"site":"tantengvip","owner":"tuntun","age":5}' (length=46)object(stdClass)[127] public 'site' => string 'tantengvip' (length=10) public 'owner' => string 'tuntun' (length=6) public 'age' => int 5使用json方式:
var_dump(serialize($web));var_dump(unserialize(serialize($web)));var_dump(json_encode($web));var_dump(json_decode(json_encode($web),true));
結(jié)果:
string 'a:3:{s:4:"site";s:10:"tantengvip";s:5:"owner";s:6:"tuntun";s:3:"age";i:5;}' (length=74)array (size=3) 'site' => string 'tantengvip' (length=10) 'owner' => string 'tuntun' (length=6) 'age' => int 5string '{"site":"tantengvip","owner":"tuntun","age":5}' (length=46)array (size=3) 'site' => string 'tantengvip' (length=10) 'owner' => string 'tuntun' (length=6) 'age' => int 5我們發(fā)現(xiàn),對于前面定義的這樣一個對象或數(shù)組,用serialize和json進行序列化,反序列化回來的結(jié)果和原來是一樣的,并沒有什么區(qū)別,除了序列化的格式不同而已.
那么它們到底有何區(qū)別?以下文字總結(jié)很好,就不自己加以說明了,可以寫代碼驗證。
使用json序列化和反序列化
優(yōu)勢:
變量序列化后依然可讀
可以給其他系統(tǒng)使用,因為JSON格式是標準的
劣勢:
只對UFT-8的數(shù)據(jù)有效,其他編碼可能不能很好工作
只對stdClass類的示例有效
使用serialize方式序列化和反序列化
優(yōu)勢:
允許非UTF-8的變量
支持除了stdClass 示例外的其他實例
劣勢:
編碼后的文本對人來說是不可讀的
無法被其他語言的系統(tǒng)引用
好,寫個代碼看看:
class Test{ private $pri = 'pri'; public $class = 'Test'; public function __construct() { $this->class = 'Test construct'; $this->pri = 'pri construct'; }}$test = new Test();var_dump(serialize($test));var_dump(unserialize(serialize($test)));var_dump(json_encode($test));var_dump(json_decode(json_encode($test)));結(jié)果:
string 'O:4:"Test":2:{s:9:"?Test?pri";s:13:"pri construct";s:5:"class";s:14:"Test construct";}' (length=86)object(Test)[127] private 'pri' => string 'pri construct' (length=13) public 'class' => string 'Test construct' (length=14)string '{"class":"Test construct"}' (length=26)object(stdClass)[127] public 'class' => string 'Test construct' (length=14)我們發(fā)現(xiàn),json序列化和反序列化丟失了類中的私有成員變量,而serialize序列化和反序列化只要是類的變量都可以,但是類的成員方法都無法進行序列化和反序列化。
在一般情況,還是使用json比較好,因為json是跨平臺的通用格式,除了json,用xml也比較好。那在什么時候使用serialize方式呢?
在對一個類進行serialize反序列化的時候會默認調(diào)用魔術方法__wakeUp(),這樣就使得對象能夠重新建立起序列化時未能保留的各種狀態(tài)。例如:數(shù)據(jù)庫連接等。那就是另外一個問題了,這里不做深究了
希望本文所述對大家PHP程序設計有所幫助。
新聞熱點
疑難解答
圖片精選