[NISACTF 2022]babyupload wp

文章描述了一个CTF挑战,其中涉及一个Web应用的文件上传功能。由于代码审计发现的绝对路径拼接漏洞,上传文件名以/开头时,可以绕过限制读取服务器根目录下的flag文件。通过将文件名设置为/flag,攻击者能够直接访问到flag的内容。

[NISACTF 2022]babyupload

一开始以为是传统的文件上传,但是怎么传传不上去

在这里插入图片描述
在这里插入图片描述

按f12查看源代码,显示有/source文件,直接访问然后下载了一个备份文件

在这里插入图片描述

然后开始代码审计。。。。(难蚌)

from flask import Flask, request, redirect, g, send_from_directory
import sqlite3
import os
import uuid

app = Flask(__name__)

SCHEMA = """CREATE TABLE files (
id text primary key,
path text
);
"""


def db():
    g_db = getattr(g, '_database', None)
    if g_db is None:
        g_db = g._database = sqlite3.connect("database.db")
    return g_db


@app.before_first_request
def setup(
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Leafzzz__

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值