flask框架基本使用(3)(session与cookies)
#转载请留言联系
flask 框架基本使用(1):https://www.cnblogs.com/chichung/p/9756935.html
flask 框架基本使用(2):https://www.cnblogs.com/chichung/p/9761610.html
本文主要记录下在flask 框架下如何使用 cookie 与 session。
首先要明白几个概念。
状态保持
因为 http 是一种无状态协议,浏览器请求服务器是无状态的。
无状态:指一次用户请求时,浏览器、服务器无法知道之前这个用户做过什么,每次请求都是一次新的请求。
无状态原因:浏览器与服务器是使用 socket 套接字进行通信的,服务器将请求结果返回给浏览器之后,会关闭当前的 socket 连接,而且服务器也会在处理页面完毕之后销毁页面对象。
有时需要保持下来用户浏览的状态,比如用户是否登录过,浏览过哪些商品等
实现状态保持主要有两种方式:
在客户端存储信息使用
Cookie在服务器端存储信息使用
Session
会话
会话,英文“session”,表示从用户访问我们当前访问开始,一直到用户关闭浏览器这个过程,就是一次会话,表示用户与当前网站之间进行了一次会话。
会话的开始:用户第一次访问当前网站
会话的结束:用户关闭浏览器
会话跟踪,也叫状态保持,主要目的就是为了识别每一次访问到我们网站页面的用户的行为。
1. flask 框架下使用 cookie
cookie 是什么?
(1) cookie 指某些网站为了辨别用户身份、进行会话跟踪而储存在用户本地的数据(通常经过加密)。
(2) cookie 是由服务器端生成,发送给客户端浏览器,浏览器会将 cookie 的 key/value 保存,下次请求同一网站时就发送该cookie 给服务器(前提是浏览器设置为启用 cookie )。
(3) cookie 是存储在浏览器中的一段纯文本信息,建议不要存储敏感信息如密码,因为电脑上的浏览器可能被其它人使用。
(4) cookie 基于域名安全,不同域名的 cookie 是不能互相访问的。
(5) 当浏览器请求某网站时,会将本网站下所有 cookie 信息提交给服务器,所以在 request 中可以读取 cookie 信息
cookie的应用
(1)最典型的应用是判定注册用户是否已经登录网站,用户可能会得到提示,是否在下一次进入此网站时保留用户信息以便简化登录手续,这些都是Cookie的功用。
(2)网站的广告推送,经常遇到访问某个网站时,会弹出小窗口,展示我们曾经在购物网站上看过的商品信息。(跨域)
from flask import Flask,make_response,request app=Flask(__name__) #设置cookie
@app.route("/login")
def login():
respond = make_response("登录成功")
respond.set_cookie("islogin","")
#此处可以设置时间,例如respond.set_cookie("username","chichung",10),
#表示10s后浏览器自动删除这个cookie,如果不设置时间就是管理浏览器时清除cookie
respond.set_cookie("username","chichung")
return respond #使用cookie
@app.route("/center")
def center():
if request.cookies.get("islogin") == "":
username = request.cookies.get("username")
return "%s的个人中心"%username
else:
return "没有登录" #删除cookie
@app.route("/logout")
def logout():
respond = make_response("登出成功")
#删除cookie,就是把cookie的有效期设置为0秒
respond.set_cookie("islogin","",0)
respond.set_cookie("username","",0)
# 设置cookie必须通过response返回,否则无法设置成功
return respond if __name__ == '__main__':
app.run(debug=True)
2. flask 框架下使用 session
session是什么?
session 依赖于 cookie ,原理与 cookie 基本类型,但是 session 是保存在服务端的。
对于敏感、重要的信息,建议要存储在服务器端,不能存储在浏览器中,如用户名、余额、等级、验证码等信息。
拓展:
上面的例子用 cookies 保存着登录状态与用户名,这是什么危险的。一旦遇到会一点JS的人用了你的电脑,document.cookie="islogin=1",document.cookie="username=你的用户名",就可以登录你的主页了。
from flask import Flask,session app=Flask(__name__)
app.secret_key="hdjkewqhuirhqw4e3ibr5iu432y895&^*%(7680" #必须要写secret_key,内容可以乱填 #设置session
#session是保存在服务器中的,所以session本身的有效期就是会话期,即第一次请求到关闭浏览器这段期间
@app.route("/login")
def login():
session["islogin"]=""
session["username"]="chichung"
return "登录成功" #使用session
@app.route("/center")
def center():
if session.get("islogin") == "":
return "%s的个人中心"%session.get("username")
else:
return "没有登录" #删除session
@app.route("/logout")
def logout():
session["username"]=None
session["islogin"]=None
return "登出成功" if __name__ == '__main__':
app.run()
flask框架基本使用(3)(session与cookies)的更多相关文章
- Flask框架(五) —— session源码分析
Flask框架(五) —— session源码分析 目录 session源码分析 1.请求来了,执行__call__方法 2.__call__方法 3.调用__call__方法 3.1.ctx = s ...
- Flask框架【七】—session组件详解
一.flask session简介 flask中session组件可分为内置的session组件还有第三方flask-session组件,内置的session组件缺点: 功能单一 session是保存 ...
- Flask 框架中 上下文基础理念,包括cookie,session存储方法,requset属性,current_app模块和g模块
Flask中上下文,分为请求上下文和应用上下文.既状态留存 ,就是把变量存在某一个地方可以调用 请求上下文:实际就是request和session用法理念,既都是可以存储东西. 应用上下文:既变量共享 ...
- flask框架--cookie,session
今天我又给大家分享一下怎么用flask框架来实现像淘宝购物车一样存储数据,并且把存储的数据删除,这个方法可以用两个方法都可以做成,一个是cookie,另一个是session. session是依赖于c ...
- 初识Flask框架,以及Flask中的模板语言jinjia2和Flask内置的Session
一.web框架的对比 首先我们先来看下比较火的web框架 1.Django: 优点:大而全,所有组件都是组织内部开发高度定制化,教科书级别的框架 缺点:大到浪费资源,请求的时候需要的资源较高 2.Fl ...
- Flask框架(二)—— 反向解析、配置信息、路由系统、模板、请求响应、闪现、session
Flask框架(二)—— 反向解析.配置信息.路由系统.模板.请求响应.闪现.session 目录 反向解析.配置信息.路由系统.模板.请求响应.闪现.session 一.反向解析 1.什么是反向解析 ...
- Flask框架(三)—— 请求扩展、中间件、蓝图、session源码分析
Flask框架(三)—— 请求扩展.中间件.蓝图.session源码分析 目录 请求扩展.中间件.蓝图.session源码分析 一.请求扩展 1.before_request 2.after_requ ...
- Python自动化运维之30、Flask框架
Flask 官网:http://flask.pocoo.org/ flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是 ...
- Flask框架
FLask框架的简单介绍 Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请 ...
随机推荐
- java练习题——字符串
一.动手动脑之String.equals()方法: 判断s1和s2的内容相同s1.equals(s2). 判断s1和s2的地址相同s1 == s2. 二.整理String类的Length().char ...
- android 多行文本显示的textView
package com.zhangyue.iReader.common.view; import android.content.Context; import android.graphics.Ca ...
- 路由vue-router进阶
目录 1. 导航守卫 1.1. 全局守卫 1.2. 全局解析守卫 1.3. 全局后置钩子 1.4. 路由独享的守卫 1.5. 组件内的守卫 1.6. 完整的导航解析流程 2. 路由元信息 3. 获取数 ...
- 四大VDI客户端 总有一款适合你
[TechTarget中国原创] 交付虚拟桌面时IT管理员必须要考虑到用户如何访问虚拟桌面,因为这会影响用户体验以及VDI部署最终的成败. IT可以转向简便的HTML5客户端,HTML 5客户端功能丰 ...
- SuperHelper——灵活通用的、开源的.Net ORM微型框架
SuperHelper是博主利用业余时间编写的一个ORM微型框架,除了可以提高开发效率,与其它ORM框架相比,博主更加喜欢SuperHelper的使用简单.适用范围广的特点. 简介 SuperHelp ...
- iOS 中 AFNetworking HTTPS 的使用
由于我们公司由HTTP转HTTPS,出现了一系列问题特此记录下. 一.HTTPS 二.App Transport Security 三.iOS 中用HTTPS 注意的问题 四.使用 AFNetwork ...
- 常用模块(random)
import randomimport string# dt = random.randint(1,2) # 从1-2间取随机数,包括1.2# dt = random.randrange(1,3) # ...
- Windows7中如何让python2和python3共存并使用pip
1.下载安装python2和python3 分别下载python2.7.exe.python3.6.exe并安装到C盘.E盘(如图) 2.配置环境变量 打开“系统变量”中的path文本框(如图 ...
- Python3.7在win10下安装PyAudio库以及实现音频的录制与播放
Python3.7 无法安装pyaudio 度娘的结果基本都是这个,pip install pyaudio.....然而十有八九你的电脑不买账,会报错. 报错信息: running install r ...
- Python全栈工程师(面向对象)
ParisGabriel 每天坚持手写 一天一篇 决定坚持几年 为了梦想为了信仰 开局一张图 Python人工智能从入门到精通 day16补充: 异常处理 文件 ...