138,【5】buuctf web [RootersCTF2019]I_<3_Flask

进入靶场

这段代码是利用 Python 的类继承和反射机制来尝试执行系统命令读取flag.txt文件内容

  1. ''.__class__:空字符串对象调用__class__属性,得到str类,即字符串的类型。
  2. __class__.__base__str类的__base__属性指向其基类,在 Python 中str是新式类,其基类是object
  3. __base__.__subclasses__()object类的__subclasses__()方法会返回object类的所有子类的列表。
  4. [132]:从上述子类列表中取出索引为 132 的类,不同 Python 版本该索引对应的类可能不同,一般来说这里可能是与执行系统命令相关的类(比如subprocess.Popen所在的相关类层次结构中的类)。
  5. __init__.__globals__:获取该类的__init__方法的全局命名空间字典。
  6. ['popen']:从全局命名空间字典中获取popen函数对象,popen函数可用于执行系统命令。
  7. ('cat flag.txt').read():调用popen函数执行cat flag.txt命令读取文件内容,并通过read()方法获取命令执行的输出结果。
相关推荐
极梦网络无忧2 小时前
OpenClaw 基础使用说明(中文版)
python
codeJinger2 小时前
【Python】操作Excel文件
python·excel
XLYcmy3 小时前
一个针对医疗RAG系统的数据窃取攻击工具
python·网络安全·ai·llm·agent·rag·ai安全
Islucas3 小时前
Claude code入门保姆级教程
python·bash·claude
萝卜白菜。3 小时前
TongWeb7.0相同的类指明加载顺序
开发语言·python·pycharm
赵钰老师4 小时前
【ADCIRC】基于“python+”潮汐、风驱动循环、风暴潮等海洋水动力模拟实践技术应用
python·信息可视化·数据分析
爬山算法4 小时前
MongoDB(80)如何在MongoDB中使用多文档事务?
数据库·python·mongodb
YuanDaima20484 小时前
基于 LangChain 1.0 的检索增强生成(RAG)实战
人工智能·笔记·python·langchain·个人开发·langgraph
nbwenren5 小时前
Springboot中SLF4J详解
java·spring boot·后端