詳解PHP序列化反序列化的方法
經(jīng)常看到一些配置文件里面存放的是一些類似帶有格式的變量名稱和值,其實(shí)就是一個(gè)序列化的過(guò)程,在需要用到這些數(shù)據(jù)庫(kù)的時(shí)候會(huì)進(jìn)行一個(gè)反序列化過(guò)程,就是將這個(gè)字符串再還原成他原來(lái)的數(shù)據(jù)結(jié)構(gòu)。下面說(shuō)說(shuō)php 如何進(jìn)行數(shù)據(jù)的序列化和反序列化的。
php 將數(shù)據(jù)序列化和反序列化其實(shí)就用到兩個(gè)函數(shù),serialize 和unserialize。
serialize 將數(shù)組格式化成有序的字符串
unserialize 將數(shù)組還原成數(shù)組
例如:
$user=array('Moe','Larry','Curly');
$user=serialize($stooges);
echo '<pre>';
print_r($user);
echo '<br />';
print_r(unserialize($user));
結(jié)果:
a:3:{i:0;s:3:"Moe";i:1;s:5:"Larry";i:2;s:5:"Curly";}
Array ( [0] => Moe [1] => Larry [2] => Curly )
注意當(dāng)數(shù)組值包含如雙引號(hào)、單引號(hào)、冒號(hào)或中文等字符時(shí),它們被反序列化后,可能會(huì)出現(xiàn)亂碼或格式被打亂的問(wèn)題。
解決亂碼問(wèn)題可以使用base64_encode 和base64_decode 兩個(gè)函數(shù)。
例如:
$user=array('Moe','Larry','Curly');
$user=base64_encode(serialize($user));
$user=unserialize(base64_decode($user));
這樣就不會(huì)出現(xiàn)亂碼類的問(wèn)題了,但是base64 編碼卻增加了存儲(chǔ)字符串的長(zhǎng)度。
由以上我們可以總結(jié)出一個(gè)自己的序列化和反序列化的函數(shù)來(lái),如下:
function my_serialize($obj_array){
return base64_encode(gzcompress(serialize($obj_array)));
}
//反序列化
function my_unserialize($str){
return unserialize(gzuncompress(base64_decode($str)));
}
以上就是告訴大家php是如何進(jìn)行數(shù)據(jù)的序列化和反序列化的,并且在遇到反序列化之后,出現(xiàn)亂碼或格式被打亂的原因和解決措施,希望本文的介紹對(duì)大家的學(xué)習(xí)有所幫助。
相關(guān)文章
PHP實(shí)現(xiàn)獲取域名的方法小結(jié)
這篇文章主要介紹了PHP實(shí)現(xiàn)獲取域名的方法,實(shí)例總結(jié)了常見(jiàn)的獲取域名的方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-11-11
php中郵箱地址正則表達(dá)式實(shí)現(xiàn)與詳解
本文章不但要講述了關(guān)于正則達(dá)式而且還講述了關(guān)于郵箱正則的構(gòu)成用法詳解,有需要了解的朋友可以參考一下,同時(shí)我們也提供了多種不同的郵箱驗(yàn)證實(shí)例2012-04-04
php 多線程上下文中安全寫文件實(shí)現(xiàn)代碼
提供一個(gè)php多線程上下文中安全寫文件的實(shí)現(xiàn)方法。這個(gè)實(shí)現(xiàn)沒(méi)有使用php 的file lock機(jī)制,使用的是臨時(shí)文件機(jī)制。多線程中的各個(gè)線程都是對(duì)各自(每個(gè)線程獨(dú)占一個(gè))的臨時(shí)文件寫,然后再同步到原文件中。2009-12-12
PHP簡(jiǎn)單實(shí)現(xiàn)合并2個(gè)數(shù)字鍵數(shù)組值的方法
這篇文章主要介紹了PHP簡(jiǎn)單實(shí)現(xiàn)合并2個(gè)數(shù)字鍵數(shù)組值的方法,涉及php針對(duì)數(shù)組的遍歷、判斷、轉(zhuǎn)換等相關(guān)操作技巧,需要的朋友可以參考下2017-05-05

