news 2026/1/20 6:19:20

Flask任意文件读取+session伪造-NSSCTF-web4

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Flask任意文件读取+session伪造-NSSCTF-web4

1、打开环境,有个超链接readSomtthing,直接跳转到百度首页。

2、观察跳转URL,IP:PORT/read?url=https://baidu.com。结合提示,可能存在任意文件读取漏洞。

3、使用url= /proc/self/cmdline 读取当前进程对应的终端命令时,发现了app.py。审计代码:

# encoding:utf-8 import re, random, uuid, urllib from flask import Flask, session, request app = Flask(__name__) random.seed(uuid.getnode()) #用mac地址作为种子 app.config['SECRET_KEY'] = str(random.random() * 233) #根据上面的Mac地址,生成密钥。 app.debug = True @app.route('/') def index(): session['username'] = 'www-data' #当前用户 return 'Hello World! Read somethings' @app.route('/read') def read(): try: url = request.args.get('url') m = re.findall('^file.*', url, re.IGNORECASE) n = re.findall('flag', url, re.IGNORECASE) if m or n: return 'No Hack' res = urllib.urlopen(url) return res.read() except Exception as ex: print str(ex) return 'no response' @app.route('/flag') def flag(): if session and session['username'] == 'fuck': #需要让username = fuck,才会读取flag return open('/flag.txt').read() else: return 'Access denied' if __name__ == '__main__': app.run(debug=True, host="0.0.0.0")

可以确定,当前用户是www-data,路由为/。当用户为fuck,路由为/flag时,可以读取flag。由此,需要进行session伪造。

4、session伪造必须要知道scret_key,代码里给出了方法:

random.seed(uuid.getnode()) #用mac地址作为种子 app.config['SECRET_KEY'] = str(random.random() * 233) #根据上面的Mac地址,生成密钥。

根据url=/sys/class/net/eth0/address拿到mac地址:02:42:ac:02:16:63。开始生成scret_key(这里需要使用python2,因为这个题目的环境是2,生成密钥用3的话,长度会长一些,伪造结果不对):

import random random.seed(0x0242ac021663) #也可以转为十进制的2485376915043 print(str(random.random()*233))

结果:10.937048099。

5、拿到scret_key之后,尝试对当前的session解密,看看对不对:

用户:www-data,说明密钥是正确的,开始伪造fuck的session:

刚开始用单引号报错,后来使用双引号正常出来session。替换、刷新、才出现flag。

6、/read路由过滤了flag、file关键字,也可以考虑编码绕过直接读取flag。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/16 16:27:16

自定义枚举-–-behaviac

原文 类似于自定义类,在.h文件中,任意编写一个自定义枚举类型,然后通过宏DECLARE_BEHAVIAC_ENUM声明该枚举类型。需要注意的是,宏DECLARE_BEHAVIAC_ENUM必须定义在全局的namespace里,即放在任何命名空间之外。 如下代码…

作者头像 李华
网站建设 2026/1/19 20:32:09

1、云、虚拟化与数据存储网络:从挑战到机遇的旅程

云、虚拟化与数据存储网络:从挑战到机遇的旅程 在当今数字化的时代,信息技术(IT)领域正经历着前所未有的变革。数据的爆炸式增长、新技术的不断涌现,都给企业的信息服务带来了新的挑战和机遇。本文将深入探讨云、虚拟化和数据存储网络相关的重要话题,帮助您更好地理解如…

作者头像 李华
网站建设 2025/12/20 9:43:24

8、数据足迹缩减:实现经济高效的数据需求增长

数据足迹缩减:实现经济高效的数据需求增长 在当今数字化时代,数据量呈爆炸式增长,企业和组织面临着数据存储、管理和保护的巨大挑战。数据足迹缩减(Data Footprint Reduction,DFR)作为应对这一挑战的关键策略,正日益受到关注。本文将深入探讨数据足迹缩减的相关内容,包…

作者头像 李华
网站建设 2025/12/26 16:41:36

10、数据存储服务与系统全解析

数据存储服务与系统全解析 1. 数据存储概述 数据存储技术用于在内部或外部、本地或远程(包括云与托管服务提供商)基础上存储和访问数据、应用程序和虚拟机。存储的位置多样,如SAN、NAS、云系统、服务器、工作站、笔记本电脑和其他便携式设备等。不同类型的存储具有不同的特…

作者头像 李华
网站建设 2026/1/14 8:59:23

14、云、虚拟和数据存储网络的管理工具解析

云、虚拟和数据存储网络的管理工具解析 1. 引言 在当今的 IT 领域,云、虚拟和数据存储网络的管理至关重要。正如 Greg Schulz 所说:“如果你只有一把锤子,那么所有东西看起来都像钉子。”这强调了工具选择和使用的重要性。本文将深入探讨云、虚拟和数据存储网络的管理工具…

作者头像 李华
网站建设 2026/1/13 15:01:27

16、数据存储网络的效率与效能提升之路

数据存储网络的效率与效能提升之路 1. 回顾与思考 在探讨数据存储网络相关话题时,我们不应局限于是否需要云、虚拟化、融合或数据存储网络环境这些问题。对于非供应商、顾问、分析师、记者或负责组织 IT 相关解决方案的人来说,购买和部署新解决方案通常是为了解决业务问题。…

作者头像 李华