Flask中flask-session

Flask中flask-session

Flask-Session是一个为Flask应用程序开发的工具,允许您轻松处理服务器端会话。会话是存储和追踪用户特定数据的方式。例如,当用户登录到应用程序时,他们的状态(即登录状态)可以保存在会话中,使他们能够在整个应用程序中移动而无需重新登录。

默认情况下,Flask存储会话数据在客户端(浏览器)的cookie中。这对于一些应用程序来说可能是足够的,但是在某些情况下,您可能希望在服务器端存储会话数据。这就是Flask-Session发挥作用的地方。Flask-Session扩展允许您将会话数据存储在各种位置,包括:

  • Redis
  • Memcached
  • 文件系统
  • MongoDB
  • SQLAlchemy(支持各种数据库,包括PostgreSQL,MySQL等)

使用Flask-Session的一个主要优点是它允许您轻松切换会话存储类型,而无需更改应用程序代码。这意味着您可以根据应用程序的需要来选择最适合的存储方案。

下面是几个更完整的使用Flask-Session将会话数据存储在不同地方的例子。这些例子都包含了一些更详细的配置选项,以及更复杂的路由处理。

注意 :以下示例假定你已经配置并运行了相应的存储系统(例如,你已经运行了一个Redis服务器,并已经安装了redis Python包)。而且,你还需要根据实际情况修改配置选项。

例1:使用Redis存储会话数据

python 复制代码
from flask import Flask, session
from flask_session import Session

app = Flask(__name__)
app.config['SECRET_KEY'] = 'super secret key'
app.config['SESSION_TYPE'] = 'redis'
app.config['SESSION_REDIS'] = 'redis://localhost:6379'

Session(app)

@app.route('/')
def index():
    if 'visit_count' in session:
        session['visit_count'] += 1
    else:
        session['visit_count'] = 1
    return 'You have visited this page {} times'.format(session['visit_count'])

例2:使用Memcached存储会话数据

python 复制代码
from flask import Flask, session
from flask_session import Session

app = Flask(__name__)
app.config['SECRET_KEY'] = 'super secret key'
app.config['SESSION_TYPE'] = 'memcached'
app.config['SESSION_MEMCACHED'] = 'localhost:11211'

Session(app)

@app.route('/')
def index():
    if 'visit_count' in session:
        session['visit_count'] += 1
    else:
        session['visit_count'] = 1
    return 'You have visited this page {} times'.format(session['visit_count'])

例3:使用MongoDB存储会话数据

python 复制代码
from flask import Flask, session
from flask_session import Session

app = Flask(__name__)
app.config['SECRET_KEY'] = 'super secret key'
app.config['SESSION_TYPE'] = 'mongodb'
app.config['SESSION_MONGODB'] = 'mongodb://localhost:27017'
app.config['SESSION_MONGODB_DB'] = 'mydb'
app.config['SESSION_MONGODB_COLLECT'] = 'mysession'

Session(app)

@app.route('/')
def index():
    if 'visit_count' in session:
        session['visit_count'] += 1
    else:
        session['visit_count'] = 1
    return 'You have visited this page {} times'.format(session['visit_count'])

例4:使用SQLAlchemy(和任何支持的数据库)存储会话数据

python 复制代码
from flask import Flask, session
from flask_session import Session
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)
app.config['SECRET_KEY'] = 'super secret key'
app.config['SESSION_TYPE'] = 'sqlalchemy'
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:tmp/test.db'  # 使用SQLite数据库
app.config['SESSION_SQLALCHEMY'] = SQLAlchemy(app)  # 使用Flask-SQLAlchemy

Session(app)

@app.route('/')
def index():
    if 'visit_count' in session:
        session['visit_count'] += 1
    else:
        session['visit_count'] = 1
    return 'You have visited this page {} times'.format(session['visit_count'])

这些例子都包含一个路由,当用户访问该路由时,它会检查会话中是否有visit_count键。如果有,就将它的值加一,如果没有,就设置它的值为1。然后,它会返回一个消息告诉用户他们已经访问了这个页面多少次。这个计数器在所有的用户请求之间都会保持,因为它被保存在会话中。

相关推荐
Luca_kill11 分钟前
MCP数据采集革命:从传统爬虫到智能代理的技术进化
爬虫·python·ai·数据采集·mcp·webscraping·集蜂云
波波00716 分钟前
ASP.NET Core 健康检查实战:不只是一个 /health 接口
后端·asp.net
zhangchaoxies16 分钟前
CSS如何实现响应式弹性网格布局_配合media query修改flex-wrap属性
jvm·数据库·python
小码哥_常21 分钟前
Spring Boot 搭建邮件发送系统:开启你的邮件自动化之旅
后端
ZC跨境爬虫1 小时前
Scrapy分布式爬虫(单机模拟多节点):豆瓣Top250项目设置与数据流全解析
分布式·爬虫·python·scrapy
sg_knight1 小时前
设计模式实战:命令模式(Command)
python·设计模式·命令模式
石榴树下的七彩鱼1 小时前
图片修复 API 接入实战:网站如何自动去除图片水印(Python / PHP / C# 示例)
图像处理·后端·python·c#·php·api·图片去水印
我叫黑大帅1 小时前
为什么TCP是三次握手?
后端·网络协议·面试
Polar__Star1 小时前
C#怎么操作Chart图表控件 C#如何用WinForms Chart控件绑定数据绘制统计图表【控件】
jvm·数据库·python
2401_897190552 小时前
CSS如何制作数字滚动效果_利用transform位移数字
jvm·数据库·python