Python反序列化漏洞(入门)

python反序列化漏洞前置知识

漏洞原理

代码中进行了反序列化操作,反序列化魔术方法可以被触发,且反序列化的参数可控

函数使用:

pickle.dump(obj, file) : 将对象序列化后保存到文件

pickle.load(file) : 读取文件, 将文件中的序列化内容反序列化为对象

pickle.dumps(obj) : 将对象序列化成字符串格式的字节流

pickle.loads(bytes_obj) : 将字符串格式的字节流反序列化为对象

 

魔术方法:

__reduce__()      反序列化时调用

__reduce_ex__()   反序列化时调用

__setstate__()    反序列化时调用

__getstate__()    序列化时调用

 

各类语言序列化和反序列化函数:

Java: Serializable Externalizable接口、fastjson、jackson、gson、ObjectInputStream.read、ObjectObjectInputStream.readUnshared、XMLDecoder.read、ObjectYaml.loadXStream.fromXML、ObjectMapper.readValue、JSON.parseObject等

PHP: serialize()、 unserialize()

Python:pickle  marshal  PyYAML  shelve  PIL  unzip

 

魔术方法利用演示:

__reduce__()和__reduce_ex__()魔术方法:对象被反序列化时自动调用

 

__setstate__()魔术方法:对象被反序列化时自动调用

 

__getstate__()魔术方法: 对象被序列化时自动调用

 

 

python反序列化漏洞产生演示:

代码中对对象进行了反序列化触发了__reduce__()魔术方法,魔术方法中执行了传递的参数,参数意思是:执行调用计算器的系统命令

 

修改为对象传递参数值为ipconfig,成功当作系统命令执行

 

 

python代码审计工具:bandit

帮助文档:https://bandit.readthedocs.io/en/latest/start.html

安装:pip install bandit

linux:

安装后会在当前Python目录下bin

使用:bandit -r 需要审计的源码目录

 

windows:

安装后会在当前Python目录下script

使用:bandit -r 需要审计的源码目录

 

 

 

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xiaoheizi安全

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值