본문 바로가기

Write up - WEB

Dream Hack - Web Hacking / Session-basic write up

session과 쿠키 인증에 관한 문제이다.

문제 사이트를 들어갔을 때의 모습

 

login창으로 들어갔을 때

로그인 창으로 들어갈 시 로그인창이 있는 것을 확인할 수 있다. 

#!/usr/bin/python3
from flask import Flask, request, render_template, make_response, redirect, url_for

app = Flask(__name__)

try:
    FLAG = open('./flag.txt', 'r').read()
except:
    FLAG = '[**FLAG**]'

users = {
    'guest': 'guest',
    'user': 'user1234',
    'admin': FLAG
}


# this is our session storage
session_storage = {
}


@app.route('/')
def index():
    session_id = request.cookies.get('sessionid', None)
    try:
        # get username from session_storage
        username = session_storage[session_id]
    except KeyError:
        return render_template('index.html')

    return render_template('index.html', text=f'Hello {username}, {"flag is " + FLAG if username == "admin" else "you are not admin"}')


@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'GET':
        return render_template('login.html')
    elif request.method == 'POST':
        username = request.form.get('username')
        password = request.form.get('password')
        try:
            # you cannot know admin's pw
            pw = users[username]
        except:
            return '<script>alert("not found user");history.go(-1);</script>'
        if pw == password:
            resp = make_response(redirect(url_for('index')) )
            session_id = os.urandom(32).hex()
            session_storage[session_id] = username
            resp.set_cookie('sessionid', session_id)
            return resp
        return '<script>alert("wrong password");history.go(-1);</script>'


@app.route('/admin')
def admin():
    # developer's note: review below commented code and uncomment it (TODO)

    #session_id = request.cookies.get('sessionid', None)
    #username = session_storage[session_id]
    #if username != 'admin':
    #    return render_template('index.html')

    return session_storage


if __name__ == '__main__':
    import os
    # create admin sessionid and save it to our storage
    # and also you cannot reveal admin's sesseionid by brute forcing!!! haha
    session_storage[os.urandom(32).hex()] = 'admin'
    print(session_storage)
    app.run(host='0.0.0.0', port=8000)

위에는 제공 받은 문제 파일이며 한 번 살펴보자.

 

위를 보면 계정이 3개가 있는 것을 확인할 수 있는데 각각 guest,user1234, FLAG가 암호로 걸려있음을 알 수 있다.

approute가 login말고 admin이 있었는데 session_storage를 반환한다고 하며 주석으로 session_storage에 세션값이 존재한다는 것을 알 수 있다.

/admin 경로로 들어가자 각 사용자에 관한 세션값이 들어있다.

아이디와 패스워드를 입력해서 guest 계정으로 들어왔다.

 

Sessionid의 value값에 아까 복사한 admin의 값을 복사해서 넣었다.

새로고침을 할 시 플래그값이 나오는 것을 확인할 수 있다.

'Write up - WEB' 카테고리의 다른 글