站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

如何使用Serializable接口來自定義PHP中類的序列化

關(guān)于PHP中的對象序列化這件事兒,之前我們在很早前的文章中已經(jīng)提到過__sleep()和__weakup()這兩個魔術(shù)方法。今天我們介紹的則是另外一個可以控制序列化內(nèi)容的方式,那就是使用Serializable接口。

如何使用Serializable接口來自定義PHP中類的序列化

Serializable接口

class A implements Serializable {     private $data;     public function __construct(){         echo '__construct', PHP_EOL;         $this->data = "This is Class A";     }      public function serialize(){         echo 'serialize', PHP_EOL;         return serialize($this->data);     }      public function unserialize($data){         echo 'unserialize', PHP_EOL;         $this->data = unserialize($data);     }      public function __destruct(){         echo '__destruct', PHP_EOL;     }      public function __weakup(){         echo '__weakup', PHP_EOL;     }      public function __sleep(){         echo '__destruct', PHP_EOL;     }      }  $a = new A(); $aSerialize = serialize($a);  var_dump($aSerialize); // "C:1:"A":23:{s:15:"This is Class A";}" $a1 = unserialize($aSerialize); var_dump($a1);

這段代碼就是使用 Serializable 接口來進行序列化處理的,注意一點哦,實現(xiàn)了 Serializable 接口的類中的 __sleep() 和 __weakup() 魔術(shù)方法就無效了哦,序列化的時候不會進入它們。

Serializable 這個接口需要實現(xiàn)的是兩個方法,serialize() 方法和 unserialize() 方法,是不是和那兩個魔術(shù)方法完全一樣。當然,使用的方式也是一樣的。

在這里,我們多普及一點序列化的知識。對象序列化只能序列化它們的屬性,不能序列化他們方法。如果當前能夠找到對應(yīng)的類模板,那么可以還原出這個類的方法來,如果沒有定義過這個類的模板,那么還原出來的類是沒有方法只有屬性的。我們通過這段代碼中的序列化字符串來分析:

  • "C:",指的是當前數(shù)據(jù)的類型,這個我面后面還會講,實現(xiàn) Serializable 接口的對象序列化的結(jié)果是 C: ,而沒有實現(xiàn)這個接口的對象序列化的結(jié)果是 O:
  • "A:",很明顯對應(yīng)的是類名,也就是類的::class
  • "{xxx}",對象結(jié)構(gòu)和JSON一樣,也是用的花括號

各種類型的數(shù)據(jù)進行序列化的結(jié)果

下面我們再來看下不同類型序列化的結(jié)果。要知道,在PHP中,我們除了句柄類型的數(shù)據(jù)外,其他標量類型或者是數(shù)組、對象都是可以序列化的,它們在序列化字符串中是如何表示的呢?

$int = 110; $string = '110'; $bool = FALSE; $null = NULL; $array = [1,2,3];  var_dump(serialize($int)); // "i:110;" var_dump(serialize($string)); // "s:3:"110";" var_dump(serialize($bool)); // "b:0;" var_dump(serialize($null)); // "N;" var_dump(serialize($array)); // "a:3:{i:0;i:1;i:1;i:2;i:2;i:3;}"

上面的內(nèi)容還是比較好理解的吧。不過我們還是一一說明一下:

  • 數(shù)字類型:i:<值>

  • 字符串類型:s:<長度>:<值>

  • 布爾類型:b:<值:0或1>

  • NULL類型:N;

  • 數(shù)組:a:<長度>:<內(nèi)容>

對象在使用Serializable接口序列化時要注意的地方

接下來,我們重點講講對象類型,上面已經(jīng)提到過,實現(xiàn) Serializable 接口的對象序列化后的標識是有特殊情況的。上方序列化后的字符串開頭類型標識為 "C:",那么我們看看不實現(xiàn) Serializable 接口的對象序列化后是什么情況。

// 正常對象類型序列化的結(jié)果 class B {     private $data = "This is Class B";  } $b = new B(); $bSerialize = serialize($b);  var_dump ($bSerialize); // "O:1:"B":1:{s:7:"Bdata";s:15:"This is Class B";}" var_dump($bSerialize); var_dump(unserialize("O:1:"B":1:{s:7:"

亚洲av成人无码久久精品|
精品久久人人爽天天玩人人妻|
国产精品亚洲自在线播放页码|
亚洲国产精品久久久久久|
亚洲精品无码永久在线观看你懂的
|
嫩草影院精品视频在线观看|
国产精品久久久天天影视|
亚洲精品福利在线观看|
日韩精品一区二区亚洲AV观看|
国内精品一级毛片免费看|
最新精品露脸国产在线|
国内精品久久久久久麻豆|
精品无码久久久久久久久久|
亚洲精品97久久中文字幕无码|
午夜精品久久久久久久无码|
国产成人综合日韩精品婷婷九月|
日韩精品一区二区三区色欲AV|
国产日韩一区二区三区在线观看
|
99热精品在线观看|
东京热TOKYO综合久久精品|
精品无码综合一区|
国产一区二区三精品久久久无广告
|
青青青国产精品国产精品久久久久|
a级精品九九九大片免费看|
91精品美女在线|
日韩精品无码免费专区午夜不卡|
91精品视频网站|
亚洲日韩精品无码专区网址|
国产午夜精品久久久久免费视|
国产精品免费AV片在线观看|
久久精品丝袜高跟鞋|
亚洲永久永久永久永久永久精品|
日韩精品无码久久久久久|
99精品无人区乱码1区2区3区
|
国内精品久久国产|
中文无码亚洲精品字幕|
亚洲精品亚洲人成在线|
精品国产日韩亚洲一区在线|
国产精品无码制服丝袜
|
久久99精品久久久久子伦|
2020国产精品永久在线观看|