【笔记】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 等,对所有请求生效。

相关推荐
闪闪发亮的小星星3 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq3 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波3 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.3 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余3 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.3 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央3 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
中屹指纹浏览器3 天前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记
影寂ldy3 天前
WinForm PictureBox控件 + ImageList组件 完整笔记
开发语言·笔记·swift