シリアル化は、変数を保存または送信できる文字列に変換するプロセスであり、逆シリアル化は、この文字列を適切なときに使用できるように元の変数に変換することです。これら 2 つのプロセスを組み合わせることで、データの保存と転送が容易になり、プログラムの保守性が向上します。
これら 2 つは、PHP でデータをシリアライズおよびデシリアライズするための一般的な関数です。
<?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 '<br /><br />';//反序列化$o = unserialize($s);print_r($o);//输出结果 Array ( [a] => Apple [b] => banana [c] => Coconut ) ?>
逆シリアル化後に配列値に二重引用符、一重引用符、コロンなどの文字が含まれる場合、問題が発生する可能性があります。この問題を克服するための巧妙なトリックは、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))); }
シリアル化と非シリアル化には json_encode と json_decode 形式の出力を使用します。はるかに速くなります。
$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut'); //序列化数组$s = json_encode($a);echo $s;//输出结果:{"a":"Apple","b":"banana","c":"Coconut"}echo '<br /><br />';//反序列化$o = json_decode($s);
3. var_export と eval
$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut'); //序列化数组$s = var_export($a , true);echo $s;//输出结果: array ( 'a' => 'Apple', 'b' => 'banana', 'c' => 'Coconut', )echo '<br /><br />';//反序列化eval('$my_var=' . $s . ';');print_r($my_var);
概要
上記の関数はすべて、配列変数をシリアル化する場合は通常どおり実行できますが、オブジェクトに適用する場合は異なります。たとえば、json_encode シリアル化オブジェクトは失敗します。オブジェクトを逆シリアル化する場合、unserialize と eval の効果は異なります。