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

from flask_session import Session 为什么是Session(app)这么用?

在 Flask 中,from flask_session import Session 和 Session(app) 的用法是为了配置和使用 Flask-Session 扩展,将用户的会话(Session)数据存储到服务器端(如 Redis、数据库或文件系统),而不是默认的客户端 Cookie 中。

为什么是 Session(app) 这么用?
Flask-Session 的工作机制:

Flask 默认将 Session 数据存储在客户端的 Cookie 中,通过签名确保数据不被篡改,但存在安全性(如数据泄露)和存储限制(Cookie 大小有限)。

Flask-Session 扩展将会话数据存储在服务器端(如 Redis、数据库等),客户端只保存一个 Session ID,安全性更高且支持存储更多数据。

Session(app) 的作用:

Session(app) 是 Flask-Session 扩展的初始化方法,它会将 Flask 应用的默认 Session 机制替换为 Flask-Session 的实现。

通过 Session(app),Flask-Session 会读取 Flask 应用的配置(如 SESSION_TYPE),并初始化相应的存储后端(如 Redis)。

代码示例:python
复制
from flask import Flask, session
from flask_session import Sessionapp = Flask(__name__)# 配置 Flask-Session
app.config['SESSION_TYPE'] = 'redis'  # 使用 Redis 存储 Session
app.config['SESSION_PERMANENT'] = False  # 关闭永久会话
app.config['SESSION_USE_SIGNER'] = True  # 对 Session ID 签名
app.config['SESSION_KEY_PREFIX'] = 'myapp:'  # Redis 键前缀
app.config['SESSION_REDIS'] = 'redis://localhost:6379/0'  # Redis 连接地址# 初始化 Flask-Session
Session(app)@app.route('/')
def index():# 设置 Session 数据session['username'] = 'Alice'return 'Session data set!'@app.route('/get')
def get_session():# 获取 Session 数据return f"Username: {session.get('username')}"if __name__ == '__main__':app.run(debug=True)

Session(app) 的底层原理
替换 Flask 的 Session 接口:

Flask-Session 通过 Session(app) 替换了 Flask 默认的 Session 接口,将其指向 Flask-Session 的实现。

读取配置:

Session(app) 会读取 Flask 应用的配置(如 SESSION_TYPE、SESSION_REDIS 等),并根据配置初始化存储后端。

Session 数据存储:

当用户访问应用时,Flask-Session 会生成一个唯一的 Session ID,并将其存储在客户端 Cookie 中。

实际的 Session 数据(如 session[‘username’])会被存储在服务器端(如 Redis)。

常见配置选项
配置项 说明
SESSION_TYPE Session 存储类型,如 redis、memcached、filesystem、mongodb 等。
SESSION_REDIS 如果使用 Redis,指定 Redis 连接地址(如 redis://localhost:6379/0)。
SESSION_PERMANENT 是否启用永久会话,默认为 True。
SESSION_USE_SIGNER 是否对 Session ID 签名,默认为 False。
SESSION_KEY_PREFIX 存储在 Redis 中的键前缀,默认为 session:。
SESSION_COOKIE_NAME Session Cookie 的名称,默认为 session。
总结
Session(app) 是 Flask-Session 扩展的初始化方法,用于替换 Flask 默认的 Session 机制。

通过 Session(app),Flask-Session 会根据配置将会话数据存储到服务器端(如 Redis),提升安全性和扩展性。

使用 Flask-Session 可以避免默认 Cookie Session 的限制,适合需要存储大量会话数据或对安全性要求较高的场景。

相关文章:

from flask_session import Session 为什么是Session(app)这么用?

在 Flask 中,from flask_session import Session 和 Session(app) 的用法是为了配置和使用 Flask-Session 扩展,将用户的会话(Session)数据存储到服务器端(如 Redis、数据库或文件系统),而不是默…...

AI赋能的未来城市:如何用智能化提升生活质量?

这会是我们憧憬的未来城市吗? 随着技术的不断进步和城市化进程的加速,现代城市面临着诸多挑战——交通拥堵、环境污染、能源消耗、人口老龄化等问题愈发突出。为了应对这些挑战,建设智慧城市已成为全球发展的重要趋势。在这一进程中&#xf…...

【Go】Go wire 依赖注入

1. wire 简介 wire 是一个 Golang 的依赖注入框架(类比 Spring 框架提供的依赖注入功能) ⭐ 官方文档:https://github.com/google/wire 这里关乎到编程世界当中一条好用的设计原则:A用到了B,那么B一定是通过依赖注入的…...

深度集成DeepSeek与Java开发:智能编码新纪元全攻略 [特殊字符]

一、DeepSeek:Java开发者的第二大脑 🧠 1.1 传统开发痛点VS智能开发体验 传统开发DeepSeek智能辅助效率提升对比手动编写重复代码一键生成模板代码代码量减少70%↑调试全靠断点日志智能定位缺陷根源问题排查时间缩短60%↓文档维护耗时费力自动生成更新…...

WEB前端将指定DOM生成图片并下载最佳实践(html2canvas)

前言: html2canvas 是一个 JavaScript 库,其主要作用是将 HTML 元素或其部分内容渲染为 Canvas 图像。通过它,开发者可以将网页中的任意 DOM 元素(包括文本、图片、样式等)转换为图片格式(如 PNG 或 JPEG&…...

掌握.NET Core后端发布流程,如何部署后端应用?

无论你是刚接触.NET Core的新手还是已有经验的开发者,在这篇文章中你将会学习到一系列实用的发布技巧与最佳实践,帮助你高效顺利地将.NET Core后端应用部署到生产环境中 目录 程序发布操作 Docker容器注册表 文件夹发布 导入配置文件 网站运行操作 …...

深度学习学习笔记(34周)

目录 摘要 Abstracts 简介 Hourglass Module(Hourglass 模块) 网络结构 Intermediate Supervision(中间监督) 训练过程细节 评测结果 摘要 本周阅读了《Stacked Hourglass Networks for Human Pose Estimation》&#xf…...

C++ 设计模式-备忘录模式

游戏存档实现&#xff0c;包括撤销/重做、持久化存储、版本控制和内存管理 #include <iostream> #include <memory> #include <deque> #include <stack> #include <chrono> #include <fstream> #include <sstream> #include <ct…...

TOGAF之架构标准规范-信息系统架构 | 应用架构

TOGAF是工业级的企业架构标准规范&#xff0c;信息系统架构阶段是由数据架构阶段以及应用架构阶段构成&#xff0c;本文主要描述信息系统架构阶段中的应用架构阶段。 如上所示&#xff0c;信息系统架构&#xff08;Information Systems Architectures&#xff09;在TOGAF标准规…...

第一届网谷杯

统计四场的所有题目&#xff08;共计12题&#xff0c;四场比赛一共上了21题【包括换题】&#xff09; 随便记记&#xff0c;以免老题复用&#xff08;已经复用了&#xff09; Web 文件包含 1 伪协议 http://120.202.175.143:8011/?cphp://filter/convert.base64-encode/reso…...

Linux(ubuntu) GPU CUDA 构建Docker镜像

一、创建Dockerfile FROM ubuntu:20.04#非交互式&#xff0c;以快速运行自动化任务或脚本&#xff0c;无需图形界面 ENV DEBIAN_FRONTENDnoninteractive# 安装基础工具 RUN apt-get update && apt-get install -y \curl \wget \git \build-essential \software-proper…...

mysql -DQL语句和DCL语句

DQL 数据查询语言&#xff08;Data Query Language&#xff0c;DQL&#xff09;是数据库操作语言的重要组成部分&#xff0c;主要用于从数据库中检索数据&#xff0c;核心关键字为SELECT。以下从语法结构、常见操作及示例等方面详细介绍&#xff1a; 语法结构 DQL 的标准语法…...

掌握 ElasticSearch 组合查询:Bool Query 详解与实践

掌握 ElasticSearch 组合查询&#xff1a;Bool Query 详解与实践 一、引言 (Introduction)二、Bool 查询基础2.1 什么是 Bool 查询&#xff1f;2.2 Bool 查询的四种子句2.3 语法结构 三、Bool 查询的四种子句详解与示例3.1 must 子句3.2 filter 子句3.3 should 子句3.4 must_no…...

C++ 类和对象(友元、内部类、匿名对像)

目录 一、前言 二、正文 1.友元 1.1友元函数的使用 1.1.1外部友元函数可访问类的私有成员&#xff0c;友员函数仅仅是一种声明&#xff0c;他不是类的成员函数。 1.1.2一个函数可以是多个类的友元函数 2.友元类的使用 2.1什么是友元类 2.2 友元类的关系是单向的&#x…...

PostgreSQL 常用函数

PostgreSQL 常用函数 在数据库管理系统中&#xff0c;函数是执行特定任务的基本构建块。PostgreSQL 是一个功能强大的开源关系数据库管理系统&#xff0c;提供了丰富的内置函数&#xff0c;这些函数极大地增强了数据库操作的能力。以下是一些在 PostgreSQL 中常用的函数&#…...

掌握 ElasticSearch 四种match查询的原理与应用

文章目录 一、引言 (Introduction)二、准备工作&#xff1a;创建索引和添加示例数据三、match 查询四、match_all 查询五、multi_match 查询六、match_phrase 查询七、总结 (Conclusion) 一、引言 (Introduction) 在信息爆炸的时代&#xff0c;快速准确地找到所需信息至关重要…...

解决:Conda虚拟环境中未设置CUDA_HOME的问题

背景&#xff1a;我是Ubuntu22.04系统&#xff0c;最近在复现FoundationPose算法&#xff0c;按照README构建部署环境时&#xff0c;有一步一直卡住&#xff0c;看了下是未找到CUDA_HOME这个环境变量。 网上搜了下这个错误&#xff0c;需要设置CUDA_HOME的环境变量路径&#x…...

easyexcel和poi同时存在版本问题,使用easyexcel导出excel设置日期格式

这两天在使用easyexcel导出excel的时候日期格式全都是字符串导致导出的excel列无法筛选 后来调整了一下终于弄好了&#xff0c;看一下最终效果 这里涉及到easyexcel和poi版本冲突的问题&#xff0c;一直没搞定&#xff0c;最后狠下心来把所有的都升级到了最新版&#xff0c;然…...

HarmonyOS 开发套件 介绍——下篇

HarmonyOS 开发套件 介绍——下篇 在HarmonyOS的生态中&#xff0c;开发套件作为支撑整个系统发展的基石&#xff0c;为开发者提供了丰富而强大的工具和服务。本文将深入继续介绍HarmonyOS SDK、ArkCompiler、DevEco Testing、AppGallery等核心组件&#xff0c;帮助开发者全面掌…...

关于order by的sql注入实验

实验描述 本实验基于sqli-lab的第46关进行测试 本关的sql 语句为$sql "SELECT * FROM users ORDER BY $id" 利用sort进行sql注入&#xff0c;我们可以利用报错注入&#xff0c;延时注入来爆出数据 1.报错注入 1.手工测试 爆出数据库 ?sort(extractvalue(1, c…...

DialogX主题系统深度解析:Material、iOS、MIUI多风格切换指南

DialogX主题系统深度解析&#xff1a;Material、iOS、MIUI多风格切换指南 【免费下载链接】DialogX &#x1f4ac; DialogX dialog box component library, easy to use, more customizable, more scalable, easy to achieve a variety of dialog boxes. DialogX对话框组件库&a…...

制造业、质检类20种业务场景,SQL精写技巧

在制造业、质检类业务场景中&#xff0c;经常需要基于上限&#xff08;USL&#xff09;、下限&#xff08;LSL&#xff09;字段整合标准值&#xff0c;或通过实测值&#xff08;如PH、温度等&#xff09;判断是否超出上下限。本文结合实际业务需求&#xff0c;整理了20种Oracle…...

Ryzen SDT 1.37:深度解析AMD处理器底层调试与性能调优工具

Ryzen SDT 1.37&#xff1a;深度解析AMD处理器底层调试与性能调优工具 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https:…...

2026年OpenClaw阿里云8分钟云端集成零基础部署及使用教程【超详细】

2026年OpenClaw阿里云8分钟云端集成零基础部署及使用教程【超详细】。如何集成OpenClaw&#xff1f;还在为部署OpenClaw到处找教程踩坑吗&#xff1f;别再瞎折腾了&#xff01;OpenClaw一键部署攻略来了&#xff0c;无需代码、只需两步&#xff0c;新手小白也能轻松拥有专属AI助…...

HomeAssistant自动化进阶:让德业除湿机联动天气传感器,实现真正的智能除湿

HomeAssistant自动化进阶&#xff1a;德业除湿机与天气传感器的智能联动实战 最近在调试德业除湿机时发现&#xff0c;单纯依赖室外湿度作为触发条件存在明显缺陷——室内外湿度差异可能高达20%&#xff0c;且温度、人员活动等因素都会影响实际需求。本文将分享如何通过HomeAss…...

Windows右键菜单终极清理指南:ContextMenuManager高效管理完整教程

Windows右键菜单终极清理指南&#xff1a;ContextMenuManager高效管理完整教程 【免费下载链接】ContextMenuManager &#x1f5b1;️ 纯粹的Windows右键菜单管理程序 项目地址: https://gitcode.com/gh_mirrors/co/ContextMenuManager 你是否厌倦了每次右键点击文件时&…...

51单片机数码管显示入门:从硬件接线到代码实战,手把手教你点亮第一个数字

51单片机数码管实战指南&#xff1a;从硬件搭建到动态显示的全流程解析 第一次拿到51单片机开发板和数码管时&#xff0c;那些密密麻麻的引脚和杜邦线确实让人望而生畏。记得我刚开始接触时&#xff0c;花了整整一个下午才让第一个数字"0"亮起来。本文将带你避开所有…...

紧急预警:Dify v0.12.3升级后Webhook签名机制变更!3类存量集成即将失效(附热修复补丁)

第一章&#xff1a;紧急预警&#xff1a;Dify v0.12.3升级后Webhook签名机制变更&#xff01;3类存量集成即将失效&#xff08;附热修复补丁&#xff09; Dify v0.12.3 版本于 2024-06-15 正式发布&#xff0c;核心变更之一是强制启用 RFC 8941 兼容的 Webhook 签名验证机制&am…...

高效视频修复方案:Untrunc工具深度解析与实战指南

高效视频修复方案&#xff1a;Untrunc工具深度解析与实战指南 【免费下载链接】untrunc Restore a truncated mp4/mov. Improved version of ponchio/untrunc 项目地址: https://gitcode.com/gh_mirrors/un/untrunc 在数字媒体时代&#xff0c;视频文件意外损坏是每个内…...

2025届最火的AI写作助手实测分析

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 一种借助自然语言处理技术的智能工具&#xff0c;是 AI 写作软件&#xff0c;它能够帮用户迅…...