關於PHP中的 serialize () 和 unserialize () 的使用(即關於PHP中的值與已儲存的表示的相互轉換)

來源:互聯網
上載者:User

標籤:constant   相互   ima   dna   func   就會   變數   相互轉換   引用   

有時,我們會碰到這樣的資料(字串)

1 a:3:{i:0;s:44:"/Uploads/images/2017-07-21/5971a9a08ad57.png";i:1;s:44:"/Uploads/images/2017-07-21/5971a9a5eb19c.png";i:2;s:44:"/Uploads/images/2017-07-21/5971a9a99e7df.png";}

面對這樣的字串要想按照常規思路以分隔字元拆分字串的話會相當麻煩,其實,這種字串是經過 serialize()  函數序列化後的字串。示範如下:

1.寫一個數組

1 $asd = array(‘/Uploads/images/2017-07-21/5971a9a08ad57.png‘,‘/Uploads/images/2017-07-21/5971a9a08ad57.png‘,‘/Uploads/images/2017-07-21/5971a9a08ad57.png‘);

2.利用 serialize() 函數序列化這個數組,此時我們就會得到類似於一開始我們碰到的那種字串

1 dump(serialize($asd));

3.再利用 unserialize() 函數將序列化後的字串轉換回 PHP 的值

1 $qwe = serialize($asd);2 dump(unserialize($qwe));

註:

serialize --  產生一個可儲存的值的表示

 

serialize() 返回字串,此字串包含了表示 value 的位元組流,可以儲存於任何地方。

這有利於儲存或傳遞 PHP 的值,同時不丟失其類型和結構。

想要將已序列化的字串變回 PHP 的值,可使用 unserialize()serialize() 可處理除了 resource 之外的任何類型。甚至可以 serialize() 那些包含了指向其自身引用的數組。你正 serialize() 的數組/對象中的引用也將被儲存。

當序列化對象時,PHP 將試圖在序列動作之前調用該對象的成員函數 __sleep()。這樣就允許對象在被序列化之前做任何清除操作。類似的,當使用 unserialize() 恢複對象時, 將調用 __wakeup() 成員函數。 

unserialize --  從已儲存的表示中建立 PHP 的值

unserialize() 對單一的已序列化的變數進行操作,將其轉換回 PHP 的值。返回的是轉換之後的值,可為 integer、float、string、array 或 object。如果傳遞的字串不可解序列化,則返回 FALSE。

關於PHP中的 serialize () 和 unserialize () 的使用(即關於PHP中的值與已儲存的表示的相互轉換)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.