专栏首页算法与编程之美Flask|设置Cookie和Session

Flask|设置Cookie和Session

欢迎点击「算法与编程之美」↑关注我们!

本文首发于微信公众号:"算法与编程之美",欢迎关注,及时了解更多此系列文章。

简介

Cookie是一个简单的保存在本地的文本文件,这个文件与特定的Web文档关联在一起,保存了一些该浏览器访问这个Web文档时的信息,当再次访问的时候这些信息可以继续拿出来使用。一般来说,Cookie的大小不超过4kb。由名称、值和其他几个用于控制Cookie有效期、安全性、使用范围的可选属性组成。

其实Session和Cookie差不多,都是为了保存用户相关的信息,但是Session是储存在服务器端,而Cookie是储存在浏览器的。

具体操作

1.操作Cookie

通过在flask.Response对象上的set_cookie方法,具体代码如下:

from flask import Flask, Response,  request
app = Flask(__name__)
@app.route('/')
def index():
     resp = Response("设置Cookie")
     resp.set_cookie('username', 'liu',)
return resp
if __name__ == "__main__":
     app.run() 

当浏览器访问的时候就能查看到刚刚设置好的Cookie:

图1 浏览器查看Cookie

还可以通过在flask.Response对象上的delete_cookie方法来删除Cookie,具体代码如下:

@app.route('/del')
def delete():
     resp = Response("删除Cookie")
     resp.delete_cookie('username')
     return resp 

这样通过访问/del时就能删除掉刚刚设置好的Cookieusername,如图所示:

图2 删除Cookie

设置Cookie的这个方法有几个属性,可以根据情况进行增添。

·key:键

·value:值

·max_age:设置过期时间(秒)

·expires:设置过期时间,时间戳的形式(1970离现在的时间)

·path:当前主域名

·domain:子域名

2.操作Session

·设置Session,通过flask.seesion即可,跟字典是一样的操作。

Session[‘username’] = ‘liu’

·获取Session,也是跟字典是一样的,session.get(‘username’)

·删除Session,通过session.pop(‘liu’)删除指定的值,通过session.clear()删除所有的值。

·有效期,如果没有设置的话,就是关闭浏览器后过期。如果设置session.parmanent=True,那么就会默认31天后过期。如果不想在31天后过期,那么可以设置app.config['PERMANENT_SESSION_LIFETIME']= timedelta(hour=2),可以指定多久后过期(比如:2小时)。

代码如下:

from flask import Flask, session
import os
app = Flask(__name__)
app.config['SECRET_KEY'] = os.urandom(24)
 
@app.route('/')
def index():
     session['username'] = 'liu'
     return '设置Session'
 
@app.route('/get_session')
def get_session():
     username = session.get('username') #获取session
     if username is None:
         return 'Null'
     return username
 
@app.route('/del_session')
def del_session():
     session.pop('username')
     return "删除Session"
 
if __name__ == "__main__":
     app.run() 

本文分享自微信公众号 - 算法与编程之美(algo_coding),作者:刘玉江

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-03-27

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JavaWeb|浅谈Cookie

    Cookie,有时也用其复数形式 Cookies。类型为“小型文本文件”,是某些网站为了辨别用户身份,进行Session跟踪而储存在用户本地终端上的数据(通常经...

    算法与编程之美
  • 前端|HTML5中的网络存储

    随着互联网的快速发展,基于网页的应用越来越普遍,同时也变得越来越复杂,为了满足日益更新的需求,会经常性的在本地设备上存储数据,例如记录历史活动信息。传统方式使用...

    算法与编程之美
  • 数据库|Flask实现简单搜索功能

    用Flask实现简单搜索功能主要是通过form的方式传值,再到数据库中查询。下面是数据库的内容,主要是实现对content进行模糊匹配。

    算法与编程之美
  • 从零开始的Spring Session(一)

    新媒体管家 Session和Cookie这两个概念,在学习java web开发之初,大多数人就已经接触过了。最近在研究跨域单点登录的实现时,发现对于Sessio...

    程序猿DD
  • SAP Engagement Center Agent Home的一段代码审查

    Jerry Wang
  • Re:从零开始的Spring Session(一)

    Session和Cookie这两个概念,在学习java web开发之初,大多数人就已经接触过了。最近在研究跨域单点登录的实现时,发现对于Session和Cook...

    kirito-moe
  • JS 如何创建、读取和删除cookie

    Cookie 为 Web 应用程序保存用户相关信息提供了一种有用的方法。例如,当用户访问咱们的站点时,可以利用 Cookie 保存用户首选项或其他信息,这样,当...

    前端小智@大迁世界
  • 一文让你彻底明白什么是一致性哈希

    整个服务器的结构由前端负载服务器(图中的4个小圈圈代表4台前端负载服务器,用于分流)和后端的服务器(图中的三个小方块,m0、m1、m2代表三台后端服务器,用于存...

    xujjj
  • window.opener.location 安全风险讨论

    在浏览器中,通过 <a> 标签或者 JavaScript 中的 window.open 函数,可以打开新页面。新页面的 window 对象中,存在一个 open...

    逸鹏
  • 新浪微博爬虫最新分享

    專 欄 ❈ 九茶,Python工程师,目前居于广州。Github知名开源爬虫QQSpider和SinaSpider作 者,经常会在CSDN上分享一些爬虫、数据...

    Python中文社区

扫码关注云+社区

领取腾讯云代金券