Python代码审计实战案例总结之反序列化和命令执行

一、介绍

Python代码审计方法多种多样,但是总而言之是根据前人思路的迁移融合扩展而形成。目前Python代码审计思路,呈现分散和多样的趋势。Python微薄研发经验以及结合实际遇到的思路和技巧进行总结,以便于朋友们的学习和参考。

二、反序列化审计实战

反序列化漏洞在Python代码审计中属于常见高危漏洞之一,它的危害性根据执行环境略有不同,本地和远程分别为7.2和10的评分。通过评分也可得知漏洞危害是显而易见。那么咱们应该如何发现这个漏洞?关于发现此种漏洞要从反序列化的模块说起,Python的反序列化模块主要为pickle、cPickle、yaml等等。有关反序列化漏洞问题在多年前就被人们所发现,目前所看到的大多数反序列化漏洞是由于应用调用了存在问题的反序列化模块。那么咱们抓住寻找反序列化模块则有可能会发现反序列化漏洞。

1. dask 命令执行漏洞(CNVD-2019-16789)

关于这个漏洞是笔者在2019年审计anaconda环境模块时候发现,提交CNVD通过验证,虽然是本地触发漏洞,但绝对是关于反序列化漏洞很好的案例,漏洞利用yaml模块问题进行反序列化。

(1) 漏洞分析

漏洞影响的版本 1.1.4 ,漏洞出现于dask模块中config.py文件,第139行。源于程序通过coolect_yaml方法中使用了yaml所导致的问题,方法用途从yaml文件收集配置。

其中第148行会判断是否为目录,传入文件就能继续执行。漏洞触发在第168行,使用了yaml.load执行了反序列化。

到此咱们通过POC触发存在反序列化的方法,即可造成代码执行问题。

(2) 漏洞POC

漏洞验证截图:

(3) 修复方法

yaml 在对于反序列化问题上,已经提供了安全反序列化的解决方法,程序使用yaml.safe_load可以进行安全的反序列化。咱们对于审计问题的修复建议根据实际情况使用。

2. NumPy 命令执行漏洞(CVE-2019-6446)

在NumPy 1.16.0版本之前存在反序列化命令执行漏洞,用户加载恶意的数据源造成代码执行。按照惯例在讲这个反序列化之前要说明Python的pickle的反序列化原理和栈指令。但不是本篇重点,故暂不讨论。

(1) 漏洞分析

咱们直接从代码层说起,漏洞的入口,lib/npyio.py 第288行附近。在这里存在使用反序列化模块的方法,并且allow_pickle值为True。allow_pickle 允许使用 Python pickles 保存对象数组,Python 中的 pickle 用于在保存到磁盘文件或从磁盘文件读取之前,对对象进行序列化和反序列化。通俗讲是个开关,并默认开启。

漏洞触发位置,位置在lib/npyio.py,第418行。这里有反序列化加载的方法。笔者将一些代码省略,直观看重点。默认格式要求ZIP文件前缀PK\x03\x04后缀PK\x05\x06,如果不满足默认的格式,则会执行pickle.load()反序列化方法。

到此执行流程为 NumPy.lib.npyio.py:load()=>pickle.py:load()。

  1. try: 
  2.     # Code to distinguish from NumPy binary files and pickles. 
  3.     _ZIP_PREFIX = b'PK\x03\x04' 
  4.     _ZIP_SUFFIX = b'PK\x05\x06' # empty zip files start with this 
  5.     ……  
  6.     if magic.startswith(_ZIP_PREFIX) or magic.startswith(_ZIP_SUFFIX): 
  7.     …… 
  8.     elif magic == format.MAGIC_PREFIX: 
  9.     …… 
  10.     else: 
  11.         # Try a pickle 
  12.         if not allow_pickle: 
  13.             raise ValueError("Cannot load file containing pickled data " 
  14.                              "when allow_pickle=False") 
  15.         try: 
  16.             return pickle.load(fid, **pickle_kwargs) 
  17.         except Exception: 
  18.             raise IOError( 
  19.                 "Failed to interpret file %s as a pickle" % repr(file)) 
  20. finally: 
  21.      …… 

(2) 漏洞POC

综上所述,编写POC如下:

  1. from numpy.lib import npyio 
  2. from numpy import __version__ 
  3. print(__version__) 
  4. import os 
  5. import pickle 
  6. class Test(object): 
  7.     def __init__(self): 
  8.         self.a = 1 
  9.     def __reduce__(self): 
  10.         return (os.system,('whoami',)) 
  11. tmpdaa = Test() 
  12. with open("test-file.pickle",'wb') as f: 
  13.     pickle.dump(tmpdaa,f) 
  14. npyio.load("test-file.pickle") 

测试结果如图:

三、命令执行审计实战

在Python模块中命令执行漏洞同样较为常见、危害较大。在审计命令执行时,大多时候程序可能会在满足特定条件下才能执行命令,也可能需要在不同的系统中才会执行命令,所以需要关注代码逻辑和某些特性。

1. numexpr 命令执行漏洞(CNVD-2019-17298)

Numexpr是机器学习模块NumPy的一个加速包,主要用于提高NumPy的性能。

(1) 漏洞分析

在该模块/numexpr/cpuinfo.py 第37行,存在执行命令的方法。

getoutput 就是存在问题的方法,通过逻辑在.popen中进行命令执行,但是由于os.WIFEXITED(status)和os.WEXITSTATUS(status)只在linux下支持所以在windows下面执行会报错。linux 下当status 为全局变量并且赋值为0的时候,os.WIFEXITED(status)结果为True,os.WEXITSTATUS(status)结果为0。根据代码逻辑:if os.WIFEXITED(status) and os.WEXITSTATUS(status) in successful_status:所以successful_status =(True,0),并通过形参传入,最终导致命令执行问题。

(2) 漏洞POC

漏洞POC和执行结果:

2. dotenv 命令执行漏洞(CNVD-2019-17299)

dotenv是一个使Node.js从文件中加载环境变量的库。

(1) 漏洞分析

漏洞存在于dotenv 0.10.1版本中的main.py文件之中,第317行,可见该方法形参传入命令和环境变量。但是由于未对可用命令进行过滤导致任意命令执行问题。

(2) 漏洞POC

漏洞POC和执行结果:

总结

通过以上案例和总结,相信咱们能够进一步提高Python审计的功力。这些漏洞在Python审计中比较典型,如果在文章中哪里存在疏忽,盼斧正。

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/148504.html<

(0)
运维的头像运维
上一篇2025-03-12 04:39
下一篇 2025-03-12 04:41

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注