本文實例講述了PHP中SERIALIZE和JSON的序列化與反序列化操作區別。分享給大家供大家參考,具體如下:
PHP中SERIALIZE和JSON序列化與反序列化區別是什麼呢,對於這個問題我們可以和小編一起來看看,具體的操作細節如下所示。
在PHP中,serialize和json兩種方式對一個對象或數組進行序列化或反序列化有什麼區別呢?
假設一個對象和一個數組:
$web = new stdClass; $web->site = 'tantengvip'; $web->owner = 'tuntun'; $web->age = 5; //和 $web = array(); $web['site'] = 'tantengvip'; $web['owner'] = 'tuntun'; $web['age'] = 5;
對它們分別用serialize函數和unserialize函數進行序列化和反序列化,看看打印結果分別是什麼,如下:
使用serialize方式:
var_dump(serialize($web)); var_dump(unserialize(serialize($web))); var_dump(json_encode($web)); var_dump(json_decode(json_encode($web)));
結果:
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 5 string '{"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));
結果:
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 5 string '{"site":"tantengvip","owner":"tuntun","age":5}' (length=46) array (size=3) 'site' => string 'tantengvip' (length=10) 'owner' => string 'tuntun' (length=6) 'age' => int 5
我們發現,對於前面定義的這樣一個對象或數組,用serialize和json進行序列化,反序列化回來的結果和原來是一樣的,並沒有什麼區別,除了序列化的格式不同而已.
那麼它們到底有何區別?以下文字總結很好,就不自己加以說明了,可以寫代碼驗證。
使用json序列化和反序列化
優勢:
變量序列化後依然可讀
可以給其他系統使用,因為JSON格式是標准的
劣勢:
只對UFT-8的數據有效,其他編碼可能不能很好工作
只對stdClass類的示例有效
使用serialize方式序列化和反序列化
優勢:
允許非UTF-8的變量
支持除了stdClass 示例外的其他實例
劣勢:
編碼後的文本對人來說是不可讀的
無法被其他語言的系統引用
好,寫個代碼看看:
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)));
結果:
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)
我們發現,json序列化和反序列化丟失了類中的私有成員變量,而serialize序列化和反序列化只要是類的變量都可以,但是類的成員方法都無法進行序列化和反序列化。
在一般情況,還是使用json比較好,因為json是跨平台的通用格式,除了json,用xml也比較好。那在什麼時候使用serialize方式呢?
在對一個類進行serialize反序列化的時候會默認調用魔術方法__wakeUp(),這樣就使得對象能夠重新建立起序列化時未能保留的各種狀態。例如:數據庫連接等。那就是另外一個問題了,這裡不做深究了
更多關於PHP相關內容感興趣的讀者可查看本站專題:《php字符串(string)用法總結》、《PHP數組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算符用法總結》、《PHP網絡編程技巧總結》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。