Home  >  Article  >  Backend Development  >  PHP Tutorial-Deserialization Method

PHP Tutorial-Deserialization Method

巴扎黑
巴扎黑Original
2016-12-07 13:25:011065browse

1. serialize and unserialize functions



These two are common functions for serializing and deserializing data in PHP.


$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut');

//Serialization Array

$s = serialize($a);

echo $s;

//Output result: a:3:{s:1:"a";s:5:"Apple";s:1: "b";s:6:"banana";s:1:"c";s:7:"Coconut";}

echo '

';

/ /Deserialization

$o = unserialize($s);

print_r($o);

//Output result Array ( [a] => Apple [b] => banana [c] => ; Coconut )

?>

When array values ​​contain characters such as double quotes, single quotes, or colons, problems may occur after they are deserialized. To overcome this problem, a neat trick is to use base64_encode and base64_decode.

$obj = array();

//Serialization

$s = base64_encode(serialize($obj));

//Deserialization

$original = unserialize(base64_decode($s));

But base64 encoding will increase the length of the string. To overcome this problem, it can be used with gzcompress.

//Define a function for serializing objects

function my_serialize( $obj )

{

Return base64_encode(gzcompress(serialize($obj)));

}

//Deserialization

function my_unserialize($txt)

{

return unserialize(gzuncompress(base64_decode($txt)));

}

2. json_encode and json_decode



Use JSON format to serialize and decode Serialization is a Good choice:



Using json_encode and json_decode format output is much faster than serialize and unserialize formats.

JSON format is readable.

JSON format returns smaller data than serialize.

The JSON format is open and portable. Other languages ​​can use it as well.

$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut');

//Serialized array

$s = json_encode($a);

echo $s;

//Output result: {"a":"Apple","b":"banana","c":"Coconut"}

echo '< br />
';

//Deserialization

$o = json_decode($s);

In the above example, the json_encode output length is obviously longer than the serialize output length in the previous example Be short.



3. var_export and eval



var_export function outputs the variable as a string; eval executes the string as a PHP code, and deserializes to obtain the content of the original variable.



$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut');



//Serialized array



$s = var_export($a , true);



echo $s;



//Output result: array ( 'a' => 'Apple', 'b' => ' banana', 'c' => 'Coconut', )



echo '

';



//Deserialization



eval(' $my_var=' . $s . ';');



print_r($my_var);

4. wddx_serialize_value and wddx deserialize



wddx_serialize_value function can serialize array variables and output them as XML strings .



$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut');



//Serialized array

$s = wddx_serialize_value($a);

echo $s;



//Output result (view the source code of the output string):

< ;data>Applebanana Coconut



echo '

';



//Deserialization

$o = wddx_deserialize($s);

print_r($o);

//Output result: Array ( [a] => Apple [b] => banana 1 => Coconut )

It can be seen that there are many XML tag characters, resulting in this The serialization of the format still takes up a lot of space.



Summary



All the above functions can be executed normally when serializing array variables, but it is different when applied to objects. For example, json_encode serialized objects will fail. When deserializing objects, unserialize and eval will have different effects.

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn