flask-session是flask框架的session组件,由于原来flask内置session使用签名cookie保存,该组件则将支持session保存到多个地方,如:

  • redis
  • memcached
  • filesystem
  • mongodb
  • sqlalchmey

安装

  1. pip3 install flask-session

存储方式

redis

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -
  3. import redis
  4. from flask import Flask, session
  5. from flask_session import Session
  6.  
  7. app = Flask(__name__)
  8. app.debug = True
  9. app.secret_key = 'xxxx'
  10.  
  11. app.config['SESSION_TYPE'] = 'redis' # session类型为redis
  12. app.config['SESSION_PERMANENT'] = False # 如果设置为True,则关闭浏览器session就失效。
  13. app.config['SESSION_USE_SIGNER'] = False # 是否对发送到浏览器上session的cookie值进行加密
  14. app.config['SESSION_KEY_PREFIX'] = 'session:' # 保存到session中的值的前缀
  15. app.config['SESSION_REDIS'] = redis.Redis(host='127.0.0.1', port='', password='') # 用于连接redis的配置
  16.  
  17. Session(app)
  18.  
  19. @app.route('/index')
  20. def index():
  21. session['k1'] = 'v1'
  22. return 'xx'
  23.  
  24. if __name__ == '__main__':
  25. app.run()

memcached

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -
  3. import redis
  4. from flask import Flask, session
  5. from flask_session import Session
  6. import memcache
  7.  
  8. app = Flask(__name__)
  9. app.debug = True
  10. app.secret_key = 'xxxx'
  11.  
  12. app.config['SESSION_TYPE'] = 'memcached' # session类型为redis
  13. app.config['SESSION_PERMANENT'] = True # 如果设置为True,则关闭浏览器session就失效。
  14. app.config['SESSION_USE_SIGNER'] = False # 是否对发送到浏览器上session的cookie值进行加密
  15. app.config['SESSION_KEY_PREFIX'] = 'session:' # 保存到session中的值的前缀
  16. app.config['SESSION_MEMCACHED'] = memcache.Client(['10.211.55.4:12000'])
  17.  
  18. Session(app)
  19.  
  20. @app.route('/index')
  21. def index():
  22. session['k1'] = 'v1'
  23. return 'xx'
  24.  
  25. if __name__ == '__main__':
  26. app.run()

filesystem

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -
  3. import redis
  4. from flask import Flask, session
  5. from flask_session import Session
  6.  
  7. app = Flask(__name__)
  8. app.debug = True
  9. app.secret_key = 'xxxx'
  10.  
  11. app.config['SESSION_TYPE'] = 'filesystem' # session类型为redis
  12. app.config[
  13. 'SESSION_FILE_DIR'] = '/Users/wupeiqi/PycharmProjects/grocery/96.Flask新课程/组件/2.flask-session' # session类型为redis
  14. app.config['SESSION_FILE_THRESHOLD'] = 500 # 存储session的个数如果大于这个值时,就要开始进行删除了
  15. app.config['SESSION_FILE_MODE'] = 384 # 文件权限类型
  16.  
  17. app.config['SESSION_PERMANENT'] = True # 如果设置为True,则关闭浏览器session就失效。
  18. app.config['SESSION_USE_SIGNER'] = False # 是否对发送到浏览器上session的cookie值进行加密
  19. app.config['SESSION_KEY_PREFIX'] = 'session:' # 保存到session中的值的前缀
  20.  
  21. Session(app)
  22.  
  23. @app.route('/index')
  24. def index():
  25. session['k1'] = 'v1'
  26. session['k2'] = 'v1'
  27. return 'xx'
  28.  
  29. if __name__ == '__main__':
  30. app.run()

mongodb

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -
  3. import redis
  4. from flask import Flask, session
  5. from flask_session import Session
  6. import pymongo
  7.  
  8. app = Flask(__name__)
  9. app.debug = True
  10. app.secret_key = 'xxxx'
  11.  
  12. app.config['SESSION_TYPE'] = 'mongodb' # session类型为redis
  13.  
  14. app.config['SESSION_MONGODB'] = pymongo.MongoClient()
  15. app.config['SESSION_MONGODB_DB'] = 'mongo的db名称(数据库名称)'
  16. app.config['SESSION_MONGODB_COLLECT'] = 'mongo的collect名称(表名称)'
  17.  
  18. app.config['SESSION_PERMANENT'] = True # 如果设置为True,则关闭浏览器session就失效。
  19. app.config['SESSION_USE_SIGNER'] = False # 是否对发送到浏览器上session的cookie值进行加密
  20. app.config['SESSION_KEY_PREFIX'] = 'session:' # 保存到session中的值的前缀
  21.  
  22. Session(app)
  23.  
  24. @app.route('/index')
  25. def index():
  26. session['k1'] = 'v1'
  27. session['k2'] = 'v1'
  28. return 'xx'
  29.  
  30. if __name__ == '__main__':
  31. app.run()

mongodb操作简单示例:

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3. from pymongo import MongoClient
  4.  
  5. # 创建链接
  6. conn = MongoClient('47.93.4.198', 27017)
  7.  
  8. # 选择数据库
  9. db = conn['db1']
  10.  
  11. # 选择表
  12. posts = db['posts']
  13.  
  14. post_data = {
  15. 'name': 'alex',
  16. 'age': 18
  17. }
  18.  
  19. # 表中插入数据
  20. # result = posts.insert_one(post_data)
  21.  
  22. # 获取一条数据
  23. # row = posts.find_one()
  24. # print(row)
  25.  
  26. # # 获取多条数据
  27. # rows = posts.find()
  28. # for row in rows:
  29. # print(row)
  30.  
  31. # 删除多条数据
  32. # rows = posts.delete_many(filter={})
  33. # print(rows)
  34.  
  35. # 更新多条数据
  36. # posts.update({}, {'name': 'wupeiqi'})

sqlalchemy

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -
  3. import redis
  4. from flask import Flask, session
  5. from flask_session import Session as FSession
  6. from flask_sqlalchemy import SQLAlchemy
  7.  
  8. app = Flask(__name__)
  9. app.debug = True
  10. app.secret_key = 'xxxx'
  11.  
  12. # 设置数据库链接
  13. app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:123@127.0.0.1:3306/fssa?charset=utf8'
  14. app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True
  15.  
  16. # 实例化SQLAlchemy
  17. db = SQLAlchemy(app)
  18.  
  19. app.config['SESSION_TYPE'] = 'sqlalchemy' # session类型为sqlalchemy
  20. app.config['SESSION_SQLALCHEMY'] = db # SQLAlchemy对象
  21. app.config['SESSION_SQLALCHEMY_TABLE'] = 'session' # session要保存的表名称
  22. app.config['SESSION_PERMANENT'] = True # 如果设置为True,则关闭浏览器session就失效。
  23. app.config['SESSION_USE_SIGNER'] = False # 是否对发送到浏览器上session的cookie值进行加密
  24. app.config['SESSION_KEY_PREFIX'] = 'session:' # 保存到session中的值的前缀
  25. FSession(app)
  26.  
  27. @app.route('/index')
  28. def index():
  29.  
  30. session['k1'] = 'v1'
  31. session['k2'] = 'v1'
  32.  
  33. return 'xx'
  34.  
  35. if __name__ == '__main__':
  36. app.run()

PS: 在写好代码后,不要着急运行,需要先执行进入终端执行一条创建数据库表的命令:

  1. bogon:pro-flask wupeiqi$ python3
  2. Python 3.5.1 (v3.5.1:37a07cee5969, Dec 5 2015, 21:12:44)
  3. [GCC 4.2.1 (Apple Inc. build 5666) (dot 3)] on darwin
  4. Type "help", "copyright", "credits" or "license" for more information.
  5. >>> from app import db
  6. >>> db.create_all()
  7. >>>

Flask组件 flask_session的更多相关文章

  1. Flask组件:flask-sqlalchemy & flask-script & flask-migrate

    flask-sqlalchemy组件 项目目录结构: flask目录 # 项目名 |--- flaskdir |--- static # 静态文件 |--- templates # 模板 |--- m ...

  2. Flask组件

    组件踩坑记录 : 先注册组件在使用配置(...) flask-script Flask Script扩展提供向Flask插入外部脚本的功能,包括运行一个开发用的服务器,一个定制的Python shel ...

  3. 第五篇 Flask组件之SQLAchemy及Flask-SQLAlchemy插件/Flask-Script/Flask-migrate/pipreqs模块

    SQLAlchemy组件 一. 介绍 SQLAlchemy是一个基于Python实现的ORM框架.该框架建立在 DB API之上,使用关系对象映射进行数据库操作,简言之便是:将类和对象转换成SQL,然 ...

  4. Flask之Flask_Session插件

    一,Flask_Session介绍 因为flask自带的session是将session存在cookie中: 所以才有了第三方Flask_session插件,可以将session存储在我们想存储的数据 ...

  5. flask组件之flask_script和flask_migrate的使用

    flask_script的使用 作用: 使用命令启动flask项目 # 在项目的启动文件中 from flask import Flask from settings import Settings ...

  6. Flask项目中整合各组件

    一.介绍 主要介绍flask_sqlalchemy.flask_script.flask_migrate这三个组件该如何整合到flask项目中,以及如何使用. # 安装组件 pip3 install ...

  7. 4.flask第三方组件

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

  8. Flask 三方组件 Flask-Session

    使用 from flask import session, Flask from flask_session import Session from redis import Redis app = ...

  9. Flask请求流程超清大图

    补充一下 request是在哪里产生的: class RequestContext(object): # app就是flask对象 self.app = app if request is None: ...

随机推荐

  1. TortoiseGit 提交代码每次需要输入用户名和密码?

    每次用TortoiseGit Pull或者Push的时候都会弹出让输入用户名.密码的框, 很麻烦 ,解决办法如下: 解决办法如下: Right click → TortoiseGit → Settin ...

  2. ThinkPHP跳转与重定向的区别

    跳转: 浏览器认为: 当前URL请求成功, 重新请求新的URL. 浏览器会 记录当前的URL 和 新的URL 在请求历史记录中. 回退, 是可以回退到, 当前的URL上的. (无论 success, ...

  3. <LeetCode OJ> 217./219. Contains Duplicate (I / II)

    Given an array of integers, find if the array contains any duplicates. Your function should return t ...

  4. Python 读取json文件

    创建json文件: { "fontFamily": "微软雅黑", "fontSize": 12, "BaseSettings&q ...

  5. Hadoop1.2.1 的 “Hello world!”

    下图是大概步骤: 下面是详细步骤,但我的代码跟上面有点不一样,但都是一个道理: 第一个程序测试 wordcount 先创建目录 hadoop fs -mkdir /wc hadoop fs -mkdi ...

  6. 实现 IteratorAggregate接口

    <?php class MyIterator implements Iterator{ private $var = array(); public function __construct($ ...

  7. Servlet与JSP九大内置对象的对应关系

    JSP对象 Servlet中怎样获得 out resp.getWriter request service方法中的req参数 response service方法中的resp参数 session re ...

  8. 【BZOJ4517】[Sdoi2016]排列计数 组合数+错排

    [BZOJ4517][Sdoi2016]排列计数 Description 求有多少种长度为 n 的序列 A,满足以下条件: 1 ~ n 这 n 个数在序列中各出现了一次 若第 i 个数 A[i] 的值 ...

  9. aiohttp笔记

    目录 简介 采集模板 一批,一次性采集 动态添加任务 动态添加任务,封装成类 简介 aiohttp需要python3.5.3以及更高的版本,它不但能做客户端爬虫,也能做服务器端,利用asyncio,协 ...

  10. angular 4 路由变化的时候实时监测刷新组件

    当路由变化的时候刷新组件 比如说要刷新header组件 在header.ts里 import {Router, NavigationEnd} from "@angular/router&qu ...