当前位置: 首页 > news >正文

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存储会话数据

from flask import Flask, session
from flask_session import Sessionapp = 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'] += 1else:session['visit_count'] = 1return 'You have visited this page {} times'.format(session['visit_count'])

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

from flask import Flask, session
from flask_session import Sessionapp = 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'] += 1else:session['visit_count'] = 1return 'You have visited this page {} times'.format(session['visit_count'])

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

from flask import Flask, session
from flask_session import Sessionapp = 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'] += 1else:session['visit_count'] = 1return 'You have visited this page {} times'.format(session['visit_count'])

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

from flask import Flask, session
from flask_session import Session
from flask_sqlalchemy import SQLAlchemyapp = 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-SQLAlchemySession(app)@app.route('/')
def index():if 'visit_count' in session:session['visit_count'] += 1else:session['visit_count'] = 1return 'You have visited this page {} times'.format(session['visit_count'])

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

http://www.lryc.cn/news/103167.html

相关文章:

  • react-Native init初始化项目报错”TypeError: cli.init is not a function“
  • 【gitlib】linux系统rpm安装gitlib最新版本
  • iOS开发-检查版本更新与强制更新控制
  • 自动化运维工具——Ansible
  • W2NER详解
  • ElementUI tabs标签页样式改造美化
  • 出海周报|Temu在美状告shein、ChatGPT安卓版上线、小红书回应闪退
  • 2023年7月26日 单例模式
  • [ 容器 ] Docker 安全及日志管理
  • 游游的排列构造
  • 拯救者Y9000K无线Wi-Fi有时不稳定?该如何解决?
  • 【业务功能篇59】Springboot + Spring Security 权限管理 【下篇】
  • 性能优化 - 前端性能监控和性能指标计算方式
  • git stash clear清空本地暂存代码
  • 消防应急照明设置要求在炼钢车间电气室的应用
  • element 表单验证 深层验证绑定
  • brew 换镜像网站
  • WIZnet W5500-EVB-Pico 静态IP配置教程(二)
  • R语言无法调用stats.dll的问题解决方案[补充]
  • 无线蓝牙耳机有什么推荐?怎么选择适合自己的耳机?七款蓝牙耳机分享
  • 【数据分析专栏之Python篇】四、pandas介绍
  • 《算法竞赛·快冲300题》每日一题:“最小生成树”
  • mysql的主键选择
  • Eureka 学习笔记1:服务端实例缓存
  • vue : 无法加载文件 C:\Users\86182\AppData\Roaming\npm\vue.ps1,因为在此系统上禁止运行脚本。
  • FLinkCDC读取MySQl时间戳时区相关问题解决汇总
  • 第三篇-Tesla P40+CentOS7+CUDA 11.7 部署实践
  • AC+FIT(瘦AP)配置浅谈
  • 【Python】PySpark 数据计算 ② ( RDD#flatMap 方法 | RDD#flatMap 语法 | 代码示例 )
  • 二叉树题目:左叶子之和