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()方法获取命令执行的输出结果。
相关推荐
海梨花6 分钟前
【从零开始学习Redis】项目实战-黑马点评D2
java·数据库·redis·后端·缓存
bug菌9 分钟前
零基础也能做出AI应用?Trae是如何打破编程"高墙"的?
后端·ai编程·trae
Java技术小馆15 分钟前
重构 Controller 的 7 个黄金法则
java·后端·面试
站大爷IP19 分钟前
Python与MySQL:从基础操作到实战技巧的完整指南
python
老歌老听老掉牙24 分钟前
SymPy 矩阵到 NumPy 数组的全面转换指南
python·线性代数·矩阵·numpy·sympy
用户40993225021226 分钟前
容器化部署FastAPI应用:如何让你的任务系统代码在云端跳舞?
后端·ai编程·trae
Java水解27 分钟前
MySQL 亿级数据表平滑分表实践:基于时间分片的架构演进
后端·mysql
站大爷IP29 分钟前
Python条件判断:从基础到进阶的实用指南
python
赛博郎中33 分钟前
pygame小游戏飞机大战_8继承精灵玩家优化
python·pygame