站長資訊網(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国片精品|
        久久久久久久久无码精品亚洲日韩|
        久久精品亚洲福利|
        91精品国产成人网在线观看
        |
        欧美精品888|
        aaa级精品久久久国产片|
        热re99久久精品国99热|
        亚洲精品无码av天堂|
        久久国产美女免费观看精品
        |
        亚洲AV永久青草无码精品|
        亚洲精品99久久久久中文字幕
        |
        欧美黑人巨大videos精品|
        国产午夜精品理论片免费观看|
        99re这里只有精品国产精品|
        国产精品天干天干综合网|
        久久精品亚洲日本波多野结衣|
        亚洲av永久无码精品网站|
        亚洲精品国产综合久久一线|
        久久久国产精品|
        久久久久久亚洲精品不卡|
        久久久久九国产精品|
        精品国产成人国产在线观看
        |
        99在线精品免费视频|
        久久精品视频免费|
        午夜精品福利视频|
        91精品国产91久久|
        国产精品最新国产精品第十页
        |
        亚洲AV无码久久精品色欲|
        无码精品A∨在线观看中文|
        亚洲AV日韩精品久久久久久|
        久久精品人人槡人妻人人玩AV|
        中文字幕日韩精品无码内射|
        亚洲欧美日韩国产一区二区三区精品|
        亚洲国产精品嫩草影院久久|
        自拍偷自拍亚洲精品情侣|
        日产欧美国产日韩精品|
        国产精品视频白浆免费视频|