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()方法获取命令执行的输出结果。
相关推荐
WX-bisheyuange1 天前
基于Spring Boot的教师个人成果管理系统的设计与实现
java·spring boot·后端
chxii1 天前
spring boot 获取HTTP 请求参数
spring boot·后端·http
桦说编程1 天前
Guava 迭代器增强类介绍
java·后端·设计模式
235161 天前
【JVM】Java为啥能跨平台?JDK/JRE/JVM的关系?
java·开发语言·jvm·spring boot·后端·spring·职场和发展
风轻扬7771 天前
SQLAlchemy2.0使用
python·sqlalchemy·orm框架
潘帕斯的雄鹰1 天前
直观理解注意力机制
python·transformer·注意力机制·自注意力机制
打酱油程序员1 天前
Python数据挖掘详细学习指南
python
courtfu1 天前
Plugin ‘mysql_native_password‘ is not loaded`
java·后端
上进小菜猪1 天前
测试自动化Replay:让数据库迁移测试回归真实场景的一把“利器”
后端
Python私教1 天前
FastAPI × SQLAlchemy 2.0 Async:从“能跑”到“可压测”的完整工程实践
后端