flask基础3-蓝图-cookie-钩函数-flask上下文-异常处理

目录

一:蓝图

1.蓝图介绍

2.使用步骤

3.蓝图中的静态资源和模板

二.cookie和session

1.cookie

2.flask中操作cookie

3.session

4.session操作步骤

三.请求钩子

 四.flask上下文

1.介绍

2.请求上下文:

3.应用上下文

3.g对象

五:异常处理

1.abort方法

2.捕获异常


 

flask基础1

 flask基础2

一:蓝图

1.蓝图介绍

在Flask中,使用蓝图Blueprint来分模块组织管理。 蓝图实际可以理解为是一个存储一组视图方法的容器对象,其具有如下特点:

一个应用可以具有多个Blueprint

可以将一个Blueprint注册到任何一个未使用的URL下比如 “/user”、“/goods”

Blueprint可以单独具有自己的模板、静态文件或者其它的通用操作方法,它并不是必须要实现应用的视图和 函数的

在一个应用初始化时,就应该要注册需要使用的Blueprint

但是一个Blueprint并不是一个完整的应用,它不能独立于应用运行,而必须要注册到某一个应用中。

2.使用步骤

1.创建一个蓝图对象

user_bp=Blueprint('user',__name__)

2.在这个蓝图上注册路由,指定静态文件,注册模板过滤器

@user_bp.route('/')
def user_info():return 'user_info模块'

3.在应用对象上注册这个蓝图对象

app.register_blueprint(user_bp)

总的来说蓝图是为了防止一个py文件中写了很多路由,不方便管理,所有我们要对这个应用进行模块化,而蓝图正好可以解决这一点

3.蓝图中的静态资源和模板

1.url前缀

指定蓝图中定义的url前缀,在应用中注册的时候使用url_prefix参数指定,加上这个以后再访问这个蓝图中的url的时候要加上这个前缀

app.regist_blueprint(user_bp,url_prefix='/user')

2.蓝图中的静态资源

再应用中,应用会自动去找项目中默认的静态资源static,而蓝图不同,蓝图对象再创建的时候不会默认注册静态目录的路由,需要我们再创建时指定static_folder参数。

user_info=Blueprint('user',__name__,static_folder='static_user')

3.蓝图中的模板

蓝图对象默认的模板目录为系统的模版目录,可以在创建蓝图对象时使用 template_folder 关键字参数设置模板目录

user_info=Blueprint('user',__name__,template_folder='user_templates')

二.cookie和session

1.cookie

Cookie是一段不超过4KB的小型文本数据,保存在客户端浏览器中,由一个名称(Name)、一个值(Value)和 其它几个用于控制Cookie有效期、安全性、使用范围的可选属性组成。其中 :

(1) Name/Value:设置Cookie的名称及相对应的值,对于认证Cookie,Value值包括Web服务器所提供的访问令 牌。

(2) Expires属性:设置Cookie的生存期。有两种存储类型的Cookie:会话性与持久性。Expires属性缺省时,为会 话性Cookie,仅保存在客户端内存中,并在用户关闭浏览器时失效;持久性Cookie会保存在用户的硬盘中,直至 生存期到或用户直接在网页中单击“注销”等按钮结束会话时才会失效 。

(3) Path属性:定义了Web站点上可以访问该Cookie的目录 。

(4) Domain属性:指定了可以访问该 Cookie 的 Web 站点或域。

2.flask中操作cookie

from flask import Flask
from flask import make_response
app=Flask(__name__)@app.route('/cookie')
def set_cookie():resp=make_response('hello zhangsan')# 参数:第一个就是cookie中的一个名称,第二个是值,第三哥关键字代表生存期为3600秒resp.set_cookie('username','zhangsan',max_age=3600)return respif __name__ == '__main__':# 运行这个应用后访问/cookie这个地址就后生成一个cookie信息app.run(debug=True)

 读取cookie和删除cookie

from flask import Flask, request
from flask import make_response
app=Flask(__name__)@app.route('/cookie')
def set_cookie():resp=make_response('hello zhangsan')# 参数:第一个就是cookie中一个值的键,第二个是值,第三哥关键字代表生存期为3600秒resp.set_cookie('username','zhangsan',max_age=3600)return resp# 获得cookie
@app.route('/get_cookie')
def get_cookie():# 先使用上面那个路由访问/cookie后设置好cookie# 在访问这个地址/get_cookie就可以得到cookie了resp=request.cookies.get('username')return resp# 删除cookie
@app.route('/delete_cookie')
def delete_cookie():# 先使用上面那个路由访问/cookie后设置好cookie# 在访问这个/delete_cookie就可以将前面设置的cookie删除resp=make_response('hello zhangsan')resp.delete_cookie('username')return respif __name__ == '__main__':# 运行这个应用后访问/cookie这个地址就后生成一个cookie信息app.run(debug=True)

3.session

Session:与cookie功能效果相同。Session与Cookie的区别在于Session是记录在服务端的,而Cookie是记录在客 户端的。

当访问服务器某个网页的时候,会在服务器端的内存里开辟一块内存,这块内存就叫做session,而这个内存是跟 浏览器关联在一起的。这个浏览器指的是浏览器窗口,或者是浏览器的子窗口,意思就是,只允许当前这个 session对应的浏览器访问,就算是在同一个机器上新启的浏览器也是无法访问的。而另外一个浏览器也需要记录 session的话,就会再启一个属于自己的session。

 session与cookie的联动

当客户端进行第一次请求时,客户端的HTTP request(cookie为空)到服务端,服务端创建session,视图函数根 据form表单填写session,请求结束时,session内容填写入response的cookie中并返回给客户端,客户端的 cookie中便保存了用户的数据。

当同一客户端再次请求时, 客户端的HTTP request中cookie已经携带数据,此时cookies不为空, 获取cookie的有 效时长,如果cookie依然有效,通过与写入时同样的签名算法将cookie中的值解密出来,若cookie已经失效,则返 回空。 再根据解密出来的内容判断服务器中是否存在对应的值。

注意:在Flask中Session的签名算法是:HMAC 和 SHA1算法

4.session操作步骤

需要先设置密钥SECRET_KEY(自己定义的,flask内部会自己加密)

from flask import Flask,sessionapp=Flask(__name__)# 设置密钥
class DefaultPas(object):SECRET_KEY='zhangsan is a fawaikuangtu'app.config.from_object(DefaultPas)@app.route('/set_session')
def set_session():session['username']='zhangsan'return '设置成功'# 读取session
@app.route('/get_session')
def get_session():username=session.get('username')return username

三.请求钩子

钩子就是钩子函数,在flask中使用装饰器实现,这些装饰器会在某一次请求的各个阶段启动,请求之前,请求之后等等。

before_first_request:在处理第一个请求前执行(比如数据库连接是否正常)(新版本flask已经移除)

before_request:每一次请求前执行(比如有没有这个请求的权力)

after_request:如果没有抛出错误,在每次请求后执行 接受一个参数:视图函数作出的响应 在此函数中可以对响应值在返回之前做最后一步修改处理 需要将参数中的响应在此参数中进行返回

teardown_request: 在每次请求后执行 接受一个参数:错误信息,如果有相关错误抛出

from flask import Flask,abortapp=Flask(__name__)# 这个方法flask新版本中已经移除
# # 在第一次之前调用
# @app.before_first_request
# def before_first_request():
#     print("准备执行第一次请求了")# 在每一次请求之前调用,这时候已经有请求了,可能在这个方法里面做请求的校验
# 如果请求的校验不成功,可以直接在此方法中进行响应,直接return之后那么就不会执行视图函数
@app.before_request
def before_request():print('每一次请求之前')# if '这一次请求的权限不够'#     return '滚一边去'# 在执行完视图函数之后会调用,并且会把视图函数所生成的响应传入,可以在此方法中对响应做最后一步统一的处理
@app.after_request
def after_request(response):print('这个视图函数已经执行完拉')return response# 请每一次请求之后都会调用,会接受一个参数,参数是服务器出现的错误信息
@app.teardown_request
def teardown_request(response):print("本次服务结束")@app.route('/')
def index():return 'index'if __name__ == '__main__':app.run(debug=True)
127.0.0.1 - - [13/Jun/2024 13:42:55] "GET / HTTP/1.1" 200 -
每一次请求之前
这个视图函数已经执行完拉
本次服务结束
每一次请求之前
这个视图函数已经执行完拉
本次服务结束
127.0.0.1 - - [13/Jun/2024 13:42:55] "GET / HTTP/1.1" 200 -

 四.flask上下文

1.介绍

上下文:即语境,语意,在程序中可以理解为在代码执行到某一时刻时,根据之前代码所做的操作以及下文即将要 执行的逻辑,可以决定在当前时刻下可以使用到的变量,或者可以完成的事情。

Flask中有两种上下文,请求上下文和应用上下文

Flask中上下文对象:相当于一个容器,保存了 Flask 程序运行过程中的一些信息。

2.请求上下文:

在两个文件中,我们如何获取另外一个文件中的请求方式,请求地址,cookie呢?

在flask中,可以直接在视图函数中使用request这个对象进行获取相关数据,而request就是请求上下文的对象,保存了当前本次请求的相关数据,请求上下文对象有:request,session

request:封装了HTTP请求的内容,针对的是http请求,比如user=request.get('user')

session:用来记录请求会话中的信息,针对的是用户信息,比如session['name']=user.id可以记录用户信息,还可以通过session.get('name')获取用户信息

3.应用上下文

它的字面意思是 应用上下文,但它不是一直存在的,它只是request context 中的一个对 app 的代理(人),所谓 local proxy。它的作用主要是帮助 request 获取当前的应用,它是伴 request 而生,随 request 而灭的。

应用上下文对象有:current_app,g

current_app:应用程序上下文,用于存储应用程序中的变量,可以通过current_app.name打印当前的app名称,也可以在current_app中存储一些变量

应用的启动脚本是哪个文件,启动时指定了哪些参数

加载了哪些配置文件,导入了哪些配置

连了哪个数据库

有哪些public的工具类、常量

应用跑再哪个机器上,IP多少,内存多大

current_app就是当前运行的flask app,在代码不方便直接操作flask的app对象时,可以操作current_app就等价于操作flask app对象

3.g对象

g作为flask中程序全局的一个临时存储变量,充当中间媒介的作用,我们可通过他对两个文件之间的变量进行传递

from flask import Flask,gapp=Flask(__name__)def db_query():user_id=g.user_iduser_name=g.user_nameprint(user_name,user_id)@app.route('/')
def get_user():g.user_id=123g.user_name='zhangsan'db_query()return '可看到函数db_query中打印的就是我们这里定义的'

五:异常处理

1.abort方法

它可以抛出一个给定状态码的HTTPException或者指定响应,例如想要用一个页面未找到异常来终止请求,你可以调用abort(404)

abort(404)

2.捕获异常

 errorhandler 装饰器 :注册一个错误处理程序,当程序抛出指定错误状态码的时候,就会调用该装饰器所装饰的方法

参数: code_or_exception – HTTP的错误状态码或指定异常

@app.errorhandler(500)
def go_where(e):return '这个服务器已经搬去别的地方了'

捕获指定异常:

@app.errorhandler(ZeroDivisionError)
def zero_division_error(e):
return '除数不能为0'

都看到这里,点个赞在走呗!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/349220.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机视觉基础课程知识点总结

图像滤波 相关: 核与图像同向应用,不翻转。 卷积: 核在应用前翻转,广泛用于信号处理和深度学习(现在常说的二维卷积就是相关)。 内积: 向量化的点积操作,是相关和卷积的一部分。 模板匹配:通过在图像中…

docker一些常用命令以及镜像构建完后部署到K8s上

docker一些常用命令以及镜像构建完后部署到K8s上 1.创建文件夹2.删除文件3.复制现有文件内容到新建文件4.打开某个文件5.查看文件列表6.解压文件(tar格式)7.解压镜像8.查看镜像9.删除镜像10.查看容器11.删除容器12.停止运行容器13.构建镜像14.启动容器15…

【GreenHills】如何使用GHS对于不同的文件进行文档内容对比

【更多软件使用问题请点击亿道电子官方网站】 1、 文档目标 利用GHS对于不同的文件进行对比。 2、 问题场景 在项目开发过程中,会对于工程进行版本管理,对于没有项目管理工具的客户,想要对于当前版本的源文件和上一版或其他版本的源文件进行…

超燃混剪热门视频素材去哪里找?超燃混剪热门素材网站分享

各位小伙伴,今天我们来聊聊怎么找到那些超燃的混剪视频素材。毕竟,谁不想制作出有趣的视频发布到朋友圈、抖音呢?那么问题来了,去哪儿找那些劲爆的素材呢?别急,今天我就给大家推荐几个超级好用的视频素材平…

Python内存管理与垃圾回收机制

目录 一、引言 二、Python内存管理概述 三、引用计数机制 四、垃圾回收机制 标记-清除(Mark-and-Sweep) 分代收集(Generational Collection) 五、内存泄漏与优化 六、总结 一、引言 Python作为一门高级编程语言&#xff…

Coze+Discord:打造你的免费AI助手(教您如何免费使用GPT-4o/Gemini等最新最强的大模型/Discord如何正确连接Coze)

文章目录 📖 介绍 📖🏡 演示环境 🏡📒 文章内容 📒📝 准备Discord📝 准备Coze🔌 连接💡 测试效果⚓️ 相关链接 ⚓️📖 介绍 📖 你是否想免费使用GPT-4o/Gemini等最新最强的大模型,但又不想花费高昂的费用?本文将教你如何通过Coze搭建Bot,并将其转发…

VMware清理拖拽缓存

磁盘空间越用越小,如何快速解决磁盘空间的问题,甩掉烦恼 安装VM tools之后可以通过拖拽的方式把文件拉入虚拟机之中。但每一次拖拽,其实都是现在cache文件夹里面生成一个同样的文件,并使用cp拷贝的方式将其拷贝到拖拽放置的目录中…

http协议,tomcat的作用

HTTP 概念:Hyper Text Transfer Protocol,超文本传输协议,规定了浏览器和服务器之间数据传输的规则。 特点: 1.基于TCP协议:面向连接,安全 2. 基于请求-响应模型的:一次请求对应一次响应 3HTTP协议是无状态的协议:对于事务处理没有记忆能…

ai 人工智能免费网站免费生成图片生成ppt

豆包 Kimi.ai - 帮你看更大的世界 生成ppt 讯飞智文 - AI在线生成PPT、Word 大家如有其它免费的欢迎推荐!!!

【研发日记】Matlab/Simulink软件优化(三)——利用NaNFlag为数据处理算法降阶

文章目录 前言 背景介绍 初始算法 优化算法 分析和应用 总结 前言 见《【研发日记】Matlab/Simulink软件优化(一)——动态内存负荷压缩》 见《【研发日记】Matlab/Simulink软件优化(二)——通信负载柔性均衡算法》 背景介绍 在一个嵌入式软件开发项目中,需要开…

CCRC-DSA 数据安全评估师

在信息技术日新月异的今天,数据的爆炸性增长已将其塑造为现代社会的宝贵财富。 然而,数据的巨大价值背后潜藏着不容忽视的风险,诸如数据泄露、恶意侵害和违规操作等问题不断引发公众和媒体的高度关注。 在这样的背景下,进行严谨…

重生之 SpringBoot3 入门保姆级学习(18、事件驱动开发解耦合)

重生之 SpringBoot3 入门保姆级学习(18、事件驱动开发解耦合) 5、SpringBoot3 核心5.1 原始开发5.2 事件驱动开发 5、SpringBoot3 核心 5.1 原始开发 LoginController package com.zhong.bootcenter.controller;import com.zhong.bootcenter.service.A…

蓝桥杯软件测试第十五届蓝桥杯模拟赛1期题目解析

PS 需要第十五界蓝桥杯模拟赛1期功能测试模板、单元测试被测代码、自动化测试被测代码请加🐧:1940787338 备注:15界蓝桥杯省赛软件测试模拟赛1期 题目1 功能测试用例1(测试用例)(15分) 【前期准备】 按步…

阿里云运维第一步(监控):开箱即用的监控

作者:仲阳 这是云的时代,现在云计算已经在各行各业广泛的应用。但是上云对于大多数客户来说,依然有很大的学习成本,如下图仅是阿里云都有几百款产品,怎么选择?怎么用?对于客户来说都是问题。“…

五、LVS原理

目录 5.1 LVS 相关原理 5.1.1 LVS集群的体系结构以及特点 5.1.1.1 LVS简介 5.1.1.2 LVS体系结构 5.1.1.3 LVS相关术语 5.1.1.4 LVS工作模式 5.1.1.5 LVS调度算法 5.1.2 LVS-DR集群介绍 5.1.2.1 LVS-DR模式工作原理 5.1.2.2 LVS-DR模式应用特点 5.1.2.3 LVS-DR模式ARP抑制 5.1…

【论文阅读】-- Omnisketch:高效的多维任意谓词高速流分析

Omnisketch:高效的多维任意谓词高速流分析 摘要1 引言2 预备知识及相关工作3 OMNISKETCH:使用任意谓词估计频率3.1 Sketch S0:Count-Min with rid-sets 用于估计带有谓词的查询3.2 Sketch S1 (OmniSketch):…

WPF学习(1)--类与类的继承

在面向对象编程中,继承是一种机制,允许一个类(称为子类或派生类)从另一个类(称为父类或基类)继承属性和方法。继承使我们能够创建一个通用类,然后根据需要扩展或修改它以创建更具体的类。以下是…

Vue3-滑动到最右验证功能

1、思路 1、在登录页面需要启动向右滑块验证 2、效果图 3、文章地址:滑动验证码的实现-vue-simple-verify 2、成分分析 1、由三块构成,分别是底部条、拖动条、拖动移动部分 2、底部条:整体容器,包括背景、边框和文字&#xf…

2024中国翻译行业发展报告

来源:中国翻译协会 近期历史回顾: 2024国内工商业储能市场研究报告.pdf 2023幸福企业白皮书.pdf 2024年欧亚地区移动经济报告.pdf 内容供应链变革 2023人工智能与首席营销官(CMO) AI科技对PC产业的影响.pdf 金融业数据应用发展报…

多应用对接企业微信授权和扫码登录

多应用对接企业微信授权和扫码登录是一种常见的企业级解决方案,它可以帮助企业实现统一的身份验证和管理,提升用户体验和安全性。本文将介绍如何实现多应用对接企业微信授权和扫码登录的方法和步骤。 # 第一步:注册企业微信开放平台应用 首…