序列化和反序列化php
㈠ php的幾種常用的數據交換格式
序列化(serialize)、變數、xml、json是PHP常見的4種文本數據交換形式。
一、序列化與反序列化
使用serialize與unserialize將可以將任何數據類型(除了資源),格式成文本數據格式,是php內置的,使用最方便,可以原汁原味將數據、對象等保存與恢復再用。
好處:使用方便,支持好。
不好:沒有通用性只有php能夠支持,文本化體積大。
可能:速度可能會慢。
二、變數
將數據寫成標準的PHP賦值語句存放在文本文件中,在程序執行過程中包含進來,通過執行賦值的操作來恢復變數。discuz經常使用這種方式做為數據的緩存。
好處:直觀。
不好:沒有通用性只有php能夠支持;使用不方便,需要自己將數據轉化成賦值語句;變數的接收方式也不夠靈活。
可能:速度會快些,與序列化相比存儲體積小。
三、xml
將數據格式化成xml存儲與解析。
好處:通用性強,可以與其它程序語言的數據交換;php已經有內置的函數支持。
不好:文本化的體積大;格式化與反解效率低。
四、json
也是類似於xml的一種文本型數據交換格式。是一種為解決xml瀏覽器數據交換復雜而出現一種新的數據格式。
好處:通用性強,目前主流的語言已經內置支持了,5.2(具體請查手冊)版本已經內置支持。php5以後使用很方便,使用方便與序列化類似。與xml相比有更好的兼容性、效率高,尤其是對於瀏覽器。而數據格式體積很小。
可能:效率問題,尤其是解析的效率問題。
㈡ 到底什麼是PHP序列化
在PHP中,序列化用於存儲或傳遞 PHP 的值的過程中,同時不丟失其類型和結構。本文講述PHP序列化的四種方案,感興趣的可以了解一下
序列化是將變數轉換為可保存或傳輸的字元串的過程;反序列化就是在適當的時候把這個字元串再轉化成原來的變數使用。這兩個過程結合起來,可以輕松地存儲和傳輸數據,使程序更具維護性。
1、什麼是PHP序列化——serialize和unserialize函數
這兩個是序列化和反序列化PHP中數據的常用函數。
$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut');
//序列化數組$s = serialize($a);echo $s;//輸出結果:a:3:{s:1:"a";s:5:"Apple";s:1:"b";s:6:"banana";s:1:"c";s:7:"Coconut";}
echo ''
;
//反序列化$o = unserialize($s);
print_r($o);
當數組值包含如雙引號、單引號或冒號等字元時,它們被反序列化後,可能會出現問題。為了克服這個問題,一個巧妙的技巧是使用base64_encode和base64_decode。
$obj = array();//序列化$s = base64_encode(serialize($obj)); //反序列化$original = unserialize(base64_decode($s));
但是base64編碼將增加字元串的長度。為了克服這個問題,可以和gzcompress一起使用。
//定義一個用來序列化對象的函數
function my_serialize( $obj ) { return base64_encode(gzcompress(serialize($obj))); }
//反序列化function my_unserialize($txt) { return unserialize(gzuncompress(base64_decode($txt))); }
2、什麼是PHP序列化——json_encode 和 json_decode
使用JSON格式序列化和反序列化是一個不錯的選擇:
使用json_encode和json_decode格式輸出要serialize和unserialize格式快得多。
JSON格式是可讀的。
JSON格式比serialize返回數據結果小。
JSON格式是開放的、可移植的。其他語言也可以使用它。
$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut');
//序列化數組$s = json_encode($a);echo $s;//輸出結果:{"a":"Apple","b":"banana","c":"Coconut"}
echo '
;
//反序列化$o = json_decode($s);
在上面的例子中,json_encode輸出長度比上個例子中serialize輸出長度顯然要短。[page]
3、什麼是PHP序列化——var_export 和 eval
var_export 函數把變數作為一個字元串輸出;eval把字元串當成PHP代碼來執行,反序列化得到最初變數的內容。
$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut');
//序列化數組$s = var_export($a , true);echo $s;//輸出結果: array ( 'a' => 'Apple', 'b' => 'banana', 'c' => 'Coconut', )
echo '
';
//反序列化eval('$my_var=' . $s . ';');
print_r($my_var);
4、什麼是PHP序列化——wddx_serialize_value 和 wddx deserialize
wddx_serialize_value函數可以序列化數組變數,並以XML字元串形式輸出。
$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut');
//序列化數組$s = wddx_serialize_value($a);echo $s;
//輸出結果(查看輸出字元串的源碼): ApplebananaCoconut
echo '
';
//反序列化$o = wddx_deserialize($s);
print_r($o);//輸出結果:Array ( [a] => Apple [b] => banana 1 => Coconut )
可以看出,XML標簽字元較多,導致這種格式的序列化還是佔了很多空間。
結論
上述所有的函數在序列化數組變數時都能正常執行,但運用到對象就不同了。例如json_encode序列化對象就會失敗。反序列化對象時,unserialize和eval將有不同的效果。
本篇《什麼是PHP序列化?這個知識點才是你應該了解到的用》到這里就已經結束了,小編一直認為,某一個編程軟體受歡迎是有一定原因的,首先吸引人的一定是其功能,環球網校的小編祝您PHP學習之路順利,如果你還想知道更多php知識,也可以點擊本站的其他文章進行學習。
㈢ php數組序列化a:1:{i:0;s:1:"1"} 的詳細解釋
1、首先創建好一個數組然後序列化,array("table" => member, "field" => 1,"rule" => -0 ,"cycle" => 24 ,"max" => 1 )。
㈣ thinkphp 反序列化有什麼用
ThinkPHP系統變數,常量,序列化,反序列化,緩存
變數的輸出:
在模板中輸出一個變數有兩種形式:{$list.name} {$list[『name』]}
在模板中可以使用系統變數,以$Think.開頭
系統變數:(舉例選幾個)
獲得伺服器的IP地址:{$Think.server.SERVER_ADDR}
獲得外部訪問的IP地址:{$Think.server.REMOTE_ADDR}
獲得伺服器的名稱:{$Think.server.SERVER_NAME}
獲得ThinkPHP內部定義的變數:
獲得當前的時間:{$Think.now}
獲得當前工具的版本:{$Think.version}
模板的頁面:{$Think.template}
模板標簽起始符號:{$Think.LDELIM }
模板標簽結束符號:{$Think.RDELIM }
系統常量:(舉例選幾個)
獲得當前文件的url :{$Think.const.__SELF__}
獲得模板配置文件的配置項的值:
{$Think.config.db_name}
在ThinkPHP模板中,對變數使用函數調節:
從控制器分配了一個字元串,在模板中,如何截取這個字元串:{$str|substr=###,5,3} 如果當前參數為函數的第一個參數,可以不寫###
在模板中載入外部文件:
使用<include file=」」> file( )和display( )的用法一樣。
If標簽的使用:<if condition=」條件1」>value1<elseifcondition=」條件2」>value2<else/>value3</if> condition裡面寫成比較運算符 eq表示等於 neq表示不等於
修改模板引擎的界定符:
在配置文件中,通過TMPL_L_DELIM修改
『TMPL_L_DELIM』=>』<{』 //修改左定界符
『TMPL_R_DELIM』=>』<{』 //修改右定界符
修改模板引擎:
'TMPL_ENGINE_TYPE'=>'Smarty'
在分組中添加配置文件,在控制器中使用直接調用C函數。
ThinkPHP的緩存機制:
數據緩存:就是講資料庫中獲得的數據保存在一個介質上,需要時直接在這個介質上讀取。
我們需要通過ThinkPHP中的cache類來實現,通過這個類的方法獲得對象,在通過這個對象來實現不同介質的數據處理。
通過傳遞不同的參數獲得不通過的數據處理對象。
$cache=Cache::getInstance(『File』);
頁面緩存:
1. 開啟緩存
在配置文件中開啟緩存,開啟緩存有一定的規則(數組格式)。
『HTML_CACHE_ON』=> true,
『HTML_CACHE_RULES』=>array(
//需要緩存的動作名=>緩存的名稱,緩存的生存周期
『show』=>array(『{:mole}_{:action}』,1000),
)
{:mole}代表當前的控制器名
{:action}代表當前的動作名(例如:show)
{$_GET}<=>{$Think.get.id} 簡寫形式{$_get}
通過地址欄傳遞一個id參數,可以實現單頁面多緩存
(通常是前台有緩存,後台不緩存)
局部不緩存:
在TP框架中,局部不緩存可以通過js , ajax , jQuery實現局部不緩存
<scripttype="text/JavaScript">
var date=Date();
document.write(date);
</script>
工廠模式:通過傳遞不同參數獲得不同的對象
單例模式:這個類只獲得一個對象,再調用這個對象方法
緩存的增刪改查
增:$cache->set(『password』,』123』,30) 第三個參數是緩存的有效期
刪:rm( ) 改:set( ) 查:get( )
序列化( serialize( ) ):保存數據的時候,將數組或者對象序列化成字元串,但是這個字元串保存了數組或者對象之前的結構和內容,當我們需要獲得這個數據的時候,在將序列化的字元串反序列化成我們需要的數組或對象(unserialize( ))
例子:
public functionxv(){
//序列化與反序列化
$a=array('name'=>'xiaoming');
$x=serialize($a);
echo $x; //輸出結果為:a:1:{s:4:"name";s:8:"xiaoming";}
echo "<br/>";
$f=unserialize($x);
print_r($f);//輸出原來的數組格式
}
㈤ 微擎PHP怎樣調用資料庫里a:1:{s:4:"type";s:1:"2";}內數組內容
$a=a:1:{s:4:"type";s:1:"2";};
$b=unserialize($a);
print_r($b);
序列化serialize()與反序列化unserialize():
序列化serialize():就是將一個變數所代表的
「內存數據」轉換為「字元串」的形式,並持久保存在硬碟(寫入文件中保存)上的一種做法,即,把「內存數據」轉換為「字元串」然後保存到文件中;
反序列化unserialize():就是將序列化之後保存在硬碟(文件)上的「字元串數據」恢復為其原來的內存形式的變數數據的一種做法,即,把文件中保存的序列化後的「字元串數據」恢復為「內存數據」;
對象的序列化:1.對一個對象進行序列化,只能將其屬性數據「保存起來」,而方法被忽略(方法不是數據),但是類名也能被保存起來,因此反序列化的位置只要有該類文件,就仍然可以將對象還原,即該對象的屬性和方法依然可以使用;
2.對象序列化的時候,會自動調用該對象所屬類的__sleep()魔術方法;
對象的反序列化:1.對一個對象進行反序列化,其實是恢復原來保存起來的屬性數據,而且,此時必須需要依賴該對象原來的所屬類;
2.對象反序列化的時候,會自動調用該對象所屬類的__wakeup()魔術方法;
總結:一般當我們需要將數據保存到文件中時會用到序列化,保存到資料庫中一般不這樣用,因為序列化和反序列化的過程其實很耗時