本文實例講述了PHP中SERIALIZE和JSON的序列化與反序列化操作區別。分享給大家供大家參考,具體如下:
PHP中SERIALIZE和JSON序列化與反序列化區別是什么呢,對于這個問題我們可以和小編一起來看看,具體的操作細節如下所示。
在PHP中,serialize和json兩種方式對一個對象或數組進行序列化或反序列化有什么區別呢?
假設一個對象和一個數組:
1
2
3
4
5
6
7
8
9
|
$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方式:
1
2
3
4
|
var_dump(serialize( $web )); var_dump(unserialize(serialize( $web ))); var_dump(json_encode( $web )); var_dump(json_decode(json_encode( $web ))); |
結果:
1
2
3
4
5
6
7
8
9
10
|
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方式:
1
2
3
4
|
var_dump(serialize( $web )); var_dump(unserialize(serialize( $web ))); var_dump(json_encode( $web )); var_dump(json_decode(json_encode( $web ),true)); |
結果:
1
2
3
4
5
6
7
8
9
10
|
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 示例外的其他實例
劣勢:
編碼后的文本對人來說是不可讀的
無法被其他語言的系統引用
好,寫個代碼看看:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
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 ))); |
結果:
1
2
3
4
5
6
7
|
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程序設計有所幫助。