web——php反序列化,pop链构造


前置知识

序列化

会变成这样

序列化解释

反序列化

public,private,protetced

当它是private时

当他是protetcted

当我在类之后在创建一个类

反序列化只可以改变变量,然后不可以自己调用里面的函数,只可以用它给出的函数调用

安全问题

------construct是构造函数

------destruct是析构函数

当我这么调用函数时

只会输出变量

当我没有创建新的对象,只将序列化后的字符串进行反序列化,它会调用析 构函数

test也被触发了,明明没有创建对象

to_string函数

所以会输出tostring

当我们这么做时

当我们不创建对象

输入 编译后的payload,也会自动执行析构函数

重要

跟前面一样,它会自动析构,

我们可以修改url

改成3,ver,他就会只执行ver

ctf反序列化问题

第一

第二

我们得尝试更改isvip中的值改为false,才可以输出flag

我们根据上面的知识3 将halse改成true

第三

前面要求要求密码相同,后面要求密码不同

改成这样

第四关

出现了多个class,还有eval

这里只可以用destruct这个魔术方法

而destruct这个函数下面的变量是上面new的一个对象

当我们直接将原函数序列化

所以我么改成backdoor

然后再改变code

第五关

出现了过滤意思是匹配o或c后面带有数字的,(i代表大小写)

之前的那个

o后面就有11,匹配到了无法继续执行

就如这样

所以我们就得将11改成+11这样就看避免数组直接接触

先将他序列化,然后再编码

第六关

前置知识

用php原生类

这个原生类是php自带的

__sleep()

序列化之前调用 的函数

它会调用sleep函数

然后不返回password

__wakeup()

__tostring()

echo会把对象当成字符串,所以会触发__tostring()

--invoke()

---call

当我们调用一个不存在的函数,这个函数不存在

------callstatic

__get()

__set()

_isset()

_unset()

__clone()

魔术方法总结

pop链前置知识(tostring和wakeup的使用)

l

当我想触发__tostring时,我们得使用上面的source,让source变成一个对象,这样------tostring()刚好能触发,所以我们这么构造

pop链构造(所以函数的触发)

找小括号,就是当成函数使用的变量

首先我们想得到flag就得使用involve这个函数,而它又由invoke来调用,所以我们就得想办法触发这个函数,就找下面有没有将变量当函数使用的就发现第22是这样的

构造推到

然后这么写

字符串逃逸(字符串减少)

序列化代码一般以}结束,以;来分隔

当我们再后面随便写东西,不会影响反序列化

加成员属性不会报错

它会将system给去掉,但最终无法反序列化,因为长度不一样

所以我们这么构造

例题

字符串增多

例题

wakeup()绕过

引用绕过

这么构造

session反序列化

第一种格式

第二种格式

第三种

漏洞(当seesion序列化和反序列化用不同的方式时会造成这个漏洞)

在save.php中,存入session并且将其序列化,当我们打开vul.php就会将这个session反序列化,就跟unserialize一样,自动执行,而默认的就会从|开始读

phar反序列化漏洞

一般改这个

例题

这里没有反序列化,但我们看到了file_exists这个函数

返回true说明有这个文件,就可以触发漏洞

就可以调用这个为协议

改成jpg也可以,都可以当初phar执行、

------------------图片取自b站橙子科技工作室,小迪

相关推荐
Honeyeagle28 分钟前
无线移动在线复合式多合一气体检测仪:工业安全监测的革新利器
运维·网络·安全
桌面运维家31 分钟前
网络运维:防火墙异常流量监控与安全配置优化
运维·网络·安全
星幻元宇VR2 小时前
VR司法矫正宣教机|构建沉浸式矫正教育新模式
科技·学习·安全·vr·虚拟现实
毕设源码-郭学长2 小时前
【开题答辩全过程】以 剧本杀交流平台为例,包含答辩的问题和答案
php
浮尘笔记3 小时前
PHP中常规通用接口验签加密规则设计
开发语言·后端·网络安全·php
昨夜见军贴06163 小时前
透析用水与消毒供应中心检测如何更可靠?AI审核与IACheck守住医疗安全底线
人工智能·安全
深蓝电商API3 小时前
安全防护体系在跨境电商平台的构建
安全·系统架构·跨境电商·代购系统·反向海淘·代购平台
Risehuxyc3 小时前
PHP 的缓存机制
开发语言·缓存·php
桌面运维家3 小时前
服务器安全:异常流量监控与DDoS溯源指南
服务器·安全·ddos
xixixi777773 小时前
安全前置设计:在智能体、模型、网络中嵌入零信任、隐私计算、智能体防护,避免“先建设后补安全”
人工智能·安全·网络安全·ai·信息安全·零信任·智能体