PHP Tutorial-Deserialization Method
Serialization is the process of converting variables into strings that can be saved or transmitted; deserialization is to convert this string into the original variable at the appropriate time for use. These two processes combine to easily store and transfer data, making the program more maintainable. Brothers PHP training (www.lampbrother.net)
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');
//Serialized 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 the array value Problems may occur when characters such as double quotes, single quotes, or colons are included when 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
Using JSON format serialization and deserialization is a good choice:
Use json_encode and json_decode format output to serialize and unserialize format is much faster.
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
The var_export function outputs the variable as a string; eval executes the string as a PHP code and deserializes it to obtain the contents 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
The wddx_serialize_value function can serialize array variables and output them as XML strings.
$a = array('a' => 'Apple' ,'b' => 'banana' , 'c' => 'Coconut');
//Serialize array
$s = wddx_serialize_value($ a);
echo $s;
//Output result (view the source code of the output string):
echo '
';
//Deserialization
$o = wddx_deserialize($s);
print_r($o);
//Output result: Array ( [a] => Apple [b] => banana 1 => Coconut )
It can be seen that XML tags have many characters, so the serialization of this 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.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Alipay PHP...

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.
