python反序列化和php反序列化类似(还没接触过java。。),相当于把程序运行时产生的变量,字典,对象实例等变换成字符串形式存储起来,以便后续调用,恢复保存前的状态
python中反序列化的库主要有两个,和,这俩除了运行效率上有区别外,其他没啥区别
的常用 *** 有
输出反序列化
读入反序列化
可以看出,和之间反序列化的结果有些许差别,我们先以目前的支持版本为主要对象,在后期给出exp的时候再补上
python3大多版本中反序列化的字符串默认版本为3号版本,我这里的默认版本为4
为了便于分析和兼容,我们统一使用号版本
在挖掘反序列化漏洞之前,我们需要了解python反序列化的流程是怎样的
直接分析反序列化出的字符串是比较困难的,我们可以使用帮助我们进行分析
指令集如下:(更具体的解析可以查看)
依照上面的表格,这一个序列化的例子就很好理解了
我们再来看另一个更复杂的例子
这样另一个更复杂的例子就分析完成了
我们现在能大体了解序列化与反序列化的流程
ctf中大多数常见的pickle反序列化,利用 *** 大都是
触发的指令码为
大意为:
取当前栈的栈顶记为,然后把它弹掉。
取当前栈的栈顶记为,然后把它弹掉。
以为参数,执行函数,把结果压进当前栈。
只要在序列化中的字符串中存在指令, *** 就会被执行,无论正常程序中是否写明了 ***
例如:
把生成的payload拿到无的正常程序中,命令仍然会被执行
记得生成payload时使用的python版本尽量与目标上的版本一致
前两个例子开头都有指令码
简单来说,指令码可以用来调用全局的的值
看下面的例子
在我们不知道中值的情况下,如何构造满足条件的payload,拿到flag呢?
利用c指令:
这是一般情况下的flag类
第27行和第37行分别进行了传参,如果我们手动把payload修改一下,将a和b的值改为,
我们成功的调用了中的变量
还记得刚才说过的build指令码吗
通过BUILD指令与C指令的结合,我们可以把改写为或其他函数
假设某个类原先没有 *** ,我们可以利用来BUILE这个对象
BUILD指令执行时,因为没有 *** ,所以就执行update,这个对象的 *** 就改为了我们指定的
接下来利用来再次BUILD这个对象,则会执行,而此时已经被我们设置为,因此实现了RCE.
看一看具体如何实现的:
还是以flag类为例
接下来需要我们手撕payload了
根据BUILD的说明,我们需要构造一个字典
接下来往字典里放值,先放一个mark
放键值对
之一次BUILD
放参数
第二次BUILD
完成
我们来试一下
成了,我们在不使用指令的情况下完成了RCE
python2 区别不是很大:
输出:
修改payload:
https://blog.csdn.net/weixin_44377940/article/details/106863514
https://zhuanlan.zhihu.com/p/89132768
本站之前公布过不少百度网盘下载工具,最好用的是pandownload,现在也能用,详见: 百度网盘第三方下载器PanDownload更新V2.0.1版本,功效强大,永远免费 SpeedPan,14...
如火如荼的“抢人大战”之后,一场优秀教师的争抢行动,正在一二线城市悄悄上演。 10月28日,东莞教育局发布消息称,为了保障公办中小学校2020年的教职员需求,面向全国公开招聘公办学校事业编制教职员岗...
本文目录一览: 1、《黑客帝国》是如何揭开新世界? 2、游戏《黑客帝国》好玩吗? 3、为什么电影《黑客帝国》系列评价很高? 4、黑客帝国枪战 5、黑客帝国哪部有枪战? 《黑客帝国》是...
找黑客更换使用名相关问题 怎么花钱雇黑客相关问题 黑客怎么黑进学校网 没有新的手机号怎么解绑微信(微信号解绑手机号码)...
每年同学们的寒假时间都是引发关注的,除了孩子们自己比较关心以外,作为家长而言也是非常想要知道的,毕竟“神兽”在家也要合理的安排才行,而寒假时间又包括了春节等中国最重视的节日,这个时间是大家可以尽情玩耍...
无需好友同意微信位置 随着移动互联网的发展,移动社交也淘汰了以往的通信沟通方式。 现在谁不会使用聊天工具呢? 而且强大,特别是腾讯的微信,现在有超过10亿的庞大用户,加上它著名的QQ有超过8亿的...