Flask-Session

因为flask自带的session是将session存在cookie中;

所以才有了第三方Flask_session插件,可以将session存储在我们想存储的数据库中(redis等)

pip install Flask-Session

将session保存在数据库中

注意redis数据库一定是在内网中的且是一台单独的服务器,防止被攻击

from flask import Flask,session,request,render_template
from flask_session import Session # 导入第三方插件
import redis # 导入redis模块,操作redis数据库的模块
app = Flask(__name__) # 指定什么数据库
app.config["SESSION_TYPE"] = "redis"
# 指定数据库的ip端口用哪个仓库存储及数据库密码,db表示redis的仓库[0-15]通过select切换,用做数据隔离
app.config["SESSION_REDIS"] = redis.Redis(host="192.168.16.16",port=6380,db=6,password="123") # 设置session过期时间,默认31天,
# app.config["PERMANENT_SESSION_LIFETIME"] = 20 # 20秒过期
# 替换Flask原有的session机制,原来session是保存在前端的cookie中的,现在我们指定session存储在数据库中
Session(app) @app.route("/login",methods=["POST","GET"])
def login():
if request.method=="GET":
return render_template("login.html")
else:
# 设置session,保存在redis数据库中,注意设置session用的是redis自带的session模块
session["username"] = 2222
# 直接从redis数据库中查看session值
uname = session.get("username") # return "200 OK" if __name__ == '__main__':
app.run("0.0.0.0",9527)

其他session设置

# app.config['SESSION_PERMANENT'] = False  # 如果设置为True,则关闭浏览器session就失效。
# app.config['SESSION_USE_SIGNER'] = False # 是否对发送到浏览器上session的cookie值进行加密
# app.config['SESSION_KEY_PREFIX'] = 'session:' # 保存到session中的值的前缀
# session的类型
config.setdefault('SESSION_TYPE', 'null')
# 在设置了session.permanent =True 后,它也会被保存在cookie中,
# key 是 _permanent,如果不清除这个cookie,即使你在以后没有设置为True,
# session也会被从cookie 中的值设置为True的
config.setdefault('SESSION_PERMANENT', True)
# 是否对发送到浏览器上 session:cookie值进行加密
config.setdefault('SESSION_USE_SIGNER', False)
# 保存到session中的值的前缀
config.setdefault('SESSION_KEY_PREFIX', 'session:')
# 文件路径
config.setdefault('SESSION_FILE_DIR',
os.path.join(os.getcwd(), 'flask_session'))
# 存储session的个数如果大于这个值时,就要开始进行删除了
config.setdefault('SESSION_FILE_THRESHOLD', 500)
# 文件权限类型
config.setdefault('SESSION_FILE_MODE', 384)

redis中的仓库,用来数据隔离

通过前端的session Key查询保存在数据库中的session

import redis,pickle

r = redis.Redis(host="192.168.16.16",port=6380,db=6,password="")

a = r.get("session:22d30ca0-323e-4244-b8de-831c8f964bc1")
# 查询出来的值是序列化后的,我们需要进行反序列化查看原始的值
print(pickle.loads(a)) # {'_permanent': True, 'username': 2222}

蓝图中的CBV模式设置session

蓝图

from flask import Blueprint,render_template,request,session
from flask import views
user = Blueprint("user",__name__) # 参数user表示蓝图唯一标识不能重复,实例化一个蓝图(Blueprint)对象 class User(views.MethodView):
def get(self):
return render_template("login.html") def post(self):
username = request.form.get("username")
password = request.form.get("password")
if username == "henry" and password == "":
# 设置session
session["username"] = "henry"
uname = session.get("username")
print(uname)
return "200 ok"
else:
return "" user.add_url_rule("/login",view_func=User.as_view(name="login"))

程序启动入口

from flask import Flask
from use.uses import uses # 导入蓝图实例
from redis import Redis
from flask_session import Session # 导入session第三方插件
app = Flask(__name__) # 指定什么数据库
app.config["SESSION_TYPE"] = "redis"
# 指定数据库的ip端口用哪个仓库存储及数据库密码,redis的仓库[0-15]通过select切换
app.config["SESSION_REDIS"] = Redis(host="192.168.16.16",port=6380,db=6,password="")
Session(app) # 注册蓝图
app.register_blueprint(uses)
if __name__ == '__main__':
app.run('127.0.0.1',9000)

redis存储如下:

Flask-第三方插件的更多相关文章

  1. flask第三方插件WTForms

    在django中有ModelForm, 虽然flask原生没有提供, 但是强大的第三方也提供了这样的功能 虽然不如django的强大, 但是基本的功能还是可以有的, 下面就来使用一哈. WTForms ...

  2. flask第三方插件DBUtils

    django中有强大的ORM支持我们来操作数据库, 但是flask没有提供对数据库的操作, 依然还是需要第三方的支持, 来提高我们的开发效率. 下载DBUtils 使用DBUtils 使用DBUtil ...

  3. Flask框架 (四)—— 请求上下文源码分析、g对象、第三方插件(flask_session、flask_script、wtforms)、信号

    Flask框架 (四)—— 请求上下文源码分析.g对象.第三方插件(flask_session.flask_script.wtforms).信号 目录 请求上下文源码分析.g对象.第三方插件(flas ...

  4. 4.flask第三方组件

    1.flask-session的使用 在flask中,有一个app.session_interface = SecureCookieSessionInterface(),也就是存session,调用o ...

  5. zabbix通过第三方插件percona监控mysql数据库

     zabbix通过第三方插件percona监控mysql数据库                                                                     ...

  6. iOS 开发:利用第三方插件来安装CoCoapods

    引言:通过上一篇博客我们知道了怎么样去通过终端来安装CoCoapods,这一篇我们着重与用第三方插件来安装CoCoapods: 1. 首先在提下链接下载插件 https://github.com/ka ...

  7. 苹果下如果安装nginx,给nginx安装markdown第三方插件

    用brew install nginx 这样安装的是最新版的nginx, 但是在有些情况下,安装第三方插件需要特定的版本,更高一级的版本可能装不上. 它的原理是下载安装包进行自动安装,建立软链,这样就 ...

  8. ThinkPHP自动获取关键词(调用第三方插件)

    ThinkPHP自动获取关键词调用在线discuz词库 先按照下图路径放好插件 方法如下 /** * 自动获取关键词(调用第三方插件) * @return [type] [description] * ...

  9. iOS 学习笔记 十 (2015.04.03)xcode第三方插件

    1.xcode第三方插件,存放路径:~/Library/Application Support/Developer/Shared/Xcode/Plug-ins

  10. zatree第三方插件

    Zabbix安装第三方插件zatree2.4.5 1.下载zatree第三方插件https://github.com/spide4k/zatree.git 2.检查PHP环境需要支持php-xml.p ...

随机推荐

  1. 怎样通过混入(Mixin)实现多继承

    js不提供现成的多重继承的方法, 但可以通过Object.assign()来手动实现: function Father1(name){ this.name = name; } function Fat ...

  2. hdu 6205 card card card 尺取法

    card card card Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  3. (十二)easyUI之表单和验证完成登录页面

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  4. What's new in C# 7.0

    1.数字分隔符(Digit Separators ) 数字分隔符使代码更具可读性.在声明变量时,可以将_添加到单独的数字中.编译器只删除_.以下代码片段在C#7中看起来更具可读性: In C# 6 l ...

  5. regarding-hsts-in-netscaler

    regarding-hsts-in-netscaler 参考: Strict Transport Security (STS or HSTS) with Citrix NetScaler and Ac ...

  6. [转载]Linux 命令详解:./configure、make、make install 命令

    [转载]Linux 命令详解:./configure.make.make install 命令 来源:https://www.cnblogs.com/tinywan/p/7230039.html 这些 ...

  7. 基于【 centos7】五 || GitLab环境搭建

    一.基于Docker部署GitLab环境搭建 1.下载镜像 docker pull beginor/gitlab-ce:11.0.1-ce.0 2.创建GitLab 的配置 (etc) . 日志 (l ...

  8. css滑动门技术

    滑动门的核心技术: 为了使各种特殊形状的背景能够自适应元素中文本内容的多少,以使自由拉伸滑动 利用css精灵(主要是背景位置)和盒子padding撑开宽度,以便适应不同字数的导航栏 一般经典布局 &l ...

  9. Java 面向对象(二)封装

    一.封装(Encapsulation) 1.概述 封装是面向对象编程的核心思想.把对象的属性和行为封装起来,其载体就是类. 面向对象编程语言是对客观世界的模拟,客观世界里成员变量都是隐藏在对象内部的, ...

  10. 【导出导入】IMPDP table_exists_action 参数的应用

    转自:https://yq.aliyun.com/articles/29337 当使用IMPDP完成数据库导入时,如遇到表已存在时,Oracle提供给我们如下四种处理方式:a.忽略(SKIP,默认行为 ...