Flask 入门系列 Cookie与session的介绍

作者:tigeriaf 时间:2022-06-21 00:45:44 

Flask 入门系列 Cookie与session的介绍

一、Cookie的使用

1、什么是Cookie

我们都知道,HTTP 协议是无状态的,也就是说,在一次请求响应结束后,服务端不会保留任何对方状态的信息,对于某些需要保留的信息,可以通过 Cookie 技术来完成,通过在请求和响应报文中添加 Cookie 数据来保存客户端的状态信息。

Web 服务器为了存储某些数据(比如用户信息) 而保存在浏览器上的小型文本数据,浏览器会在一定时间内保存它,在下次向该服务器发送请求时附带这些数据,Cookie 通常被用来进行用户会话管理(比如用户的登录状态),保存用户的一些信息。

2、在Flask中使用Cookie

Flask 中,如果想要在响应中添加一个 cookie,可以使用 response 对象的set_cookie()方法。

set_ cookie()方法的参数如下:

  • keycookie 键名

  • valuecookie

  • max_agecookie 被保存的时间,单位:秒

  • expires:具体的过期时间

  • path:限制 cookie 可用的路径,默认为整个域名

  • domaincookie 可用的域名

  • secure:设置为 True,只有通过 HTTPS 才可使用

  • httponly:设置为True,禁止客户端 js 获取 cookie

具体使用如下:


@app.route('user/<name>')

def user(name):

response = make_response('hello {}'.format(name), 200)

response.set_cookie("name", name)

return response

Flask 中,Cookie 可以通过 request 请求对象 cookies 属性获取。


@app.route('/hello')

def hello():

user = request.args.get('name')

if not user:

user = request.cookies.get("name", 'default')

return 'Hello {}!'.format(user)

二、session的使用

1、什么是session

session 指用户会话,会话可以用来保存当前请求的一些状态,以便于在请求之前共享信息。session是存储在服务端的,通过唯一标识区分用户 session,即 session id,一般情况下,session id 是存在 Cookie 中的,服务端可以获取 Cookie 中的 session id 来获取用户 session

2、Flask中的session对象

我们了解了 Cookie 最重要的功能是用来保存客户端用户的状态信息。但是存在这样一个问题,Cookie 是保存在客户端的,在浏览器中可以轻易的添加和修改 Cookie,而且如果把用户的状态信息以明文的方式存储在 Cookie 里的话,那么就可以通过伪造 Cookie 信息来伪造别人的用户信息,从而获取一些权限。为了避免这个问题,我们要对敏感的 Cookie 内容进行加密。Flask 提供了 session 对象就是用来将 Cookie 数据加密存储的。

3、在Flask中使用session

session 需要通过密钥对数据进行签名以加密数据,因此,需要先设置一个密钥app.secret_key,这里设置的密钥只是一个简单示例,在生产环境中,必须要随机生成的密钥,保证秘钥的复杂度度和随机性,才更安全。


# 设置密钥

app.secret_key = 'qwertyuiop'

@app.route('/user', methods=['POST', 'GET'])

def user():

if request.method == 'POST':

user = request.form['user_name']

session['user_name'] = request.form['user_name']

return 'Hello {}!'.format(user)

else:

if 'user_name' in session:

return 'Hello {}!'.format(session["user_name"])

session 对象的使用就跟字典一样,如上,用户使用POST请求登录后,在 session 中保存用户名,下次再使用GET请求时,不传递任何信息,也可以在 session 中获取该用户的信息。

想要清除 session 指定信息的话,例如用户名,可以使用 session.pop("user_name", None),清除全部的话可以使用session.clear()

来源:https://juejin.cn/post/7030627770677854245

标签:Flask,Cookie,session
0
投稿

猜你喜欢

  • Python使用matplotlib绘制余弦的散点图示例

    2023-04-08 03:56:29
  • sql随机记录之如何解决每次RND的结果都一样的问题?

    2007-09-11 13:24:00
  • MySQL创建数据表时设定引擎MyISAM/InnoDB操作

    2024-01-20 18:28:58
  • 深入理解JS中attribute和property的区别

    2024-04-10 16:19:32
  • php文件上传类完整实例

    2023-11-22 04:32:28
  • 如何判断发言是否为空?

    2010-01-12 20:15:00
  • 总结showModalDialog和showModelessDialog用法

    2007-11-24 08:26:00
  • 用画为5.12地震受灾同胞们祈福 Ⅱ

    2008-05-31 07:37:00
  • Python格式化输出--%s,%d,%f的代码解析

    2022-10-31 06:26:44
  • Python中的tuple元组详细介绍

    2023-03-02 03:54:47
  • 支持python的分布式计算框架Ray详解

    2023-06-20 11:34:30
  • python字符串的常用操作方法小结

    2023-11-29 03:01:37
  • python通过pil将图片转换成黑白效果的方法

    2021-07-17 22:13:16
  • Go中JSON解析时tag的使用

    2024-05-09 09:31:52
  • Python创建xml的方法

    2021-11-25 05:59:44
  • python使用wxpy实现微信消息防撤回脚本

    2023-08-22 21:21:58
  • 交互设计实用指南系列(6) –标签明晰、有效

    2010-01-21 12:39:00
  • 在Python开发环境中调用ChatGPT模型详细过程

    2022-03-25 21:59:29
  • OpenCV3.0+Python3.6实现特定颜色的物体追踪

    2021-05-13 09:01:03
  • numpy的文件存储.npy .npz 文件详解

    2023-02-08 17:16:35
  • asp之家 网络编程 m.aspxhome.com