php反序列化的一些知识

问题

php 复制代码
<?php $raw = 'O:1:"A":1:{s:1:"a";s:1:"b";}'; echo serialize(unserialize($raw)); //O:1:"A":1:{s:1:"a";s:1:"b";}?>

php反序列化的时按理说找不到A这个类,但是他没有报错,且反序列化过后得到的值依然为原来的值。

原因

当你尝试反序列化一个不存在的类时,会出现如下的一个字段,会将不存在的类转换成下面那个特殊的类,同时将原始的类名A存放在__PHP_Incomplete_Class_Name这个属性中,其余属性(其余属性是下面那个)存放方式不变。 当反序列化之后就会去找__PHP_Incomplete_Class_Name这个属性,再把里面的东西(这里指A)拿出来

问题

现在自己构造一个数组,其中有__PHP_Incomplete_Class这个类

php 复制代码
a:2:{i:0;O:8:"stdClass":1:{s:3:"abc";N}i:1;O:22:"__PHP_Incomplete_Class":1:{s:3:"abc";N;}}

现在将其反序列化后就会发生如下状况

然后我们再次进行一次序列化,出现了一点变化__PHP_Incomplete_Class中值不见了

那这时我们再进行一次反序列化,值就和第一次序列化变得不一样了,__PHP_Incomplete_Class中值成为空值了

相关推荐
咚为几秒前
Rust 错误处理的工程化演进:从 Result 到系统级边界设计
开发语言·后端·rust
qq_406176142 分钟前
深入剖析JS中的XSS与CSRF漏洞:原理、攻击与防御全指南
服务器·开发语言·前端·javascript
qq_124987075323 分钟前
基于Java的心理测试系统的设计与实现(源码+论文+部署+安装)
java·开发语言·vue.js·spring boot·计算机毕设·计算机毕业设计
写代码的【黑咖啡】35 分钟前
Python中的Statsmodels:统计建模与假设检验
开发语言·python
福楠39 分钟前
C++ | 红黑树
c语言·开发语言·数据结构·c++·算法
Jaxson Lin40 分钟前
Java编程进阶:智能仿真无人机项目1.0
java·开发语言
weixin_433179331 小时前
python - 函数 function
开发语言·python
江君是实在人1 小时前
java 面试题 redis 处理大key问题
java·开发语言·redis
进击的小头1 小时前
创建型模式:单例模式(C语言实现与实战)
c语言·开发语言·单例模式
一行注释1 小时前
ECharts柱状图横向展示与DataZoom滑动查看实现
开发语言·前端·javascript