【笔记】Flask 用 session 对象存储用户状态

Flask 的 session 对象实际上是把数据加密后存储在客户端的 Cookie 中(名为 session)。只要客户端每次请求都携带这个 Cookie,服务端就能还原出会话数据。

复制代码
from flask import Flask, session, request, jsonify

app = Flask(__name__)
# 必须设置 secret_key,用于对 session cookie 签名,防止篡改
app.secret_key = 'super-secret-key-change-me'

@app.route('/login', methods=['POST'])
def login():
    """登录接口:接收 username,写入 session"""
    username = request.form.get('username')
    if not username:
        return jsonify({'error': 'username is required'}), 400

    session['user'] = username
    session['visit_count'] = 0          # 初始化访问计数器
    return jsonify({'message': f'Login successful, welcome {username}'})

@app.route('/logout', methods=['POST'])
def logout():
    """登出接口:清除 session 中的 user"""
    session.pop('user', None)
    return jsonify({'message': 'Logged out'})

@app.route('/profile', methods=['GET'])
def profile():
    """查看登录状态"""
    user = session.get('user')
    if user:
        return jsonify({'user': user, 'status': 'logged in'})
    return jsonify({'message': 'Not logged in'}), 401

@app.route('/data', methods=['GET'])
def get_data():
    """需要登录才能访问的数据,并记录访问次数"""
    if 'user' not in session:
        return jsonify({'message': 'Unauthorized'}), 401

    session['visit_count'] += 1
    return jsonify({
        'data': 'This is protected data',
        'visit_count': session['visit_count']
    })

if __name__ == '__main__':
    app.run(debug=True)

import requests

# 创建一个会话对象,它会自动管理 Cookies 和连接池
s = requests.Session()

BASE_URL = 'http://127.0.0.1:5000'

print('=== 1. 未登录,直接访问 profile ===')
resp = s.get(f'{BASE_URL}/profile')
print(f'Status: {resp.status_code}, Body: {resp.json()}')

print('\n=== 2. 发送 POST 请求登录 ===')
resp = s.post(f'{BASE_URL}/login', data={'username': 'Alice'})
print(f'Status: {resp.status_code}, Body: {resp.json()}')

print('\n=== 3. 登录后再次访问 profile ===')
resp = s.get(f'{BASE_URL}/profile')
print(f'Status: {resp.status_code}, Body: {resp.json()}')

print('\n=== 4. 多次访问 /data,观察计数器 ===')
for i in range(3):
    resp = s.get(f'{BASE_URL}/data')
    print(f'第{i+1}次访问: {resp.json()}')

print('\n=== 5. 登出 ===')
resp = s.post(f'{BASE_URL}/logout')
print(f'Status: {resp.status_code}, Body: {resp.json()}')

print('\n=== 6. 登出后再访问 profile ===')
resp = s.get(f'{BASE_URL}/profile')
print(f'Status: {resp.status_code}, Body: {resp.json()}')

# 查看当前 Session 中保存的 Cookies
print('\n=== 当前 Session 中的 Cookies ===')
print(s.cookies.get_dict())

Flask Session 的特点

  • 存储位置在 客户端 Cookie ,服务端通过 secret_key 签名保证数据不被篡改。

  • 如果不希望暴露数据到客户端,可以使用 Flask-Session 扩展将 Session 存到 Redis 等服务器端。

requests.Session 做了什么

  • 自动管理 Cookie :第一次请求收到 Set-Cookie 后,后续请求都会自动带上 Cookie 头,无需手动处理。

  • 连接复用 :底层 urllib3 会维护连接池,对同一主机的多次请求会复用 TCP 连接,减少三次握手开销(可抓包验证)。

  • 保持其他参数:同一个 Session 可以统一设置 headers、auth 等,对所有请求生效。

相关推荐
sheeta19982 小时前
LeetCode 每日一题笔记 日期:2026.05.29 题目:3300. 最小元素
笔记·leetcode
中屹指纹浏览器3 小时前
2026指纹浏览器代理链路适配原理与多线路集群调度方案
经验分享·笔记
不羁的木木3 小时前
ArkWeb实战学习笔记05-综合实战:构建混合应用
笔记·学习·harmonyos
CC大煊3 小时前
一个Javaer的AI转型笔记(1):入坑LangChain,我的第一个hello world
笔记·langchain
元气少女小圆丶5 小时前
SenseGlove Nova 2+Unity开发笔记1
笔记·学习·unity
冰暮流星6 小时前
javascript之history对象介绍
前端·笔记
jialiguo7 小时前
博客摘录「 尚硅谷Vue3入门到实战,最新版Vue3+TypeScript前端开发教程」2024年8月7日
笔记
風清掦8 小时前
【STM32学习笔记-14】WDG看门狗 - 14.2 WWDG窗口看门狗
笔记·stm32·单片机·嵌入式硬件·学习·fpga开发
晓梦林8 小时前
bughush靶场学习笔记
笔记·学习
sakiko_9 小时前
Swift学习笔记34-MVC架构,SwiftUI与UIkit混编练习
笔记·学习·swiftui·mvc·swift