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中值成为空值了

相关推荐
haokan_Jia2 分钟前
【java使用LinkedHashMap进行list数据分组写入,顺序并没有按照原始顺序,原因分析】
java·开发语言·list
凯子坚持 c11 分钟前
C++大模型SDK开发实录(三):流式交互协议SSE解析与httplib实现原理
开发语言·c++·交互
ghie909023 分钟前
基于MATLAB的多旋翼无人机多机编队仿真实现
开发语言·matlab·无人机
少控科技35 分钟前
QT新手日记026
开发语言·qt
就是有点傻36 分钟前
C#中如何和西门子通信
开发语言·c#
液态不合群40 分钟前
如何提升 C# 应用中的性能
开发语言·算法·c#
布局呆星42 分钟前
面向对象中的封装-继承-多态
开发语言·python
柏林以东_42 分钟前
异常的分类与用法
java·开发语言
专注API从业者1 小时前
淘宝商品 API 接口架构解析:从请求到详情数据返回的完整链路
java·大数据·开发语言·数据库·架构
木千1 小时前
Qt全屏显示,在顶部工具栏的最右边显示关闭按钮
开发语言·qt