视图函数中的装饰器

-----------------------视图中的装饰器----------------------
1、如果使用的是函数视图,那么自己定义的装饰器必须放在`app.route`下面,
否则这个装饰器起不到任何作用;
2、类视图的装饰器,需要重写类视图中的一个类属性`decorators`,这个类属性
是一个列表或元组都可以,里面装的就是左右装饰器;

app.before_request

在请求(request)进入视图函数之前执行,是全局的装饰器,每次请求都会走一遍这个装饰器,这和django的中间件很像

登录验证

from flask import Flask,render_template,send_file,request,redirect,session

app = Flask(__name__,template_folder="templates")
app.secret_key="henry" @app.before_request # 相当于django的中间件
def auth():
# 白名单放行
if request.path == "/login":
return None
# 判断是否是登录用户
if session.get("username"):
return None
else:
# 如果不是登录页面就会跳转到登录页面
return redirect("login") @app.route("/login",methods=["GET","POST"])
def login():
if request.method=="GET":
return render_template("login.html")
username = request.form.get("username")
password = request.form.get("password")
# 判断用户名和密码是否正确
if username=="henry" and password=="":
# 登录成功后设置session
session["username"] = username
# 访问home页面之前会先走before_request装饰器,每个请求都会完整的走一遍before_request装饰器
return redirect("home")
else:
return "用户名或密码错误" @app.route('/home')
def home():
return "home" if __name__ == '__main__':
app.run()

request.path 是来读取当前的url地址如果是 /login 就允许直接通过 return None 你可以理解成通过放行

校验session中是否有user 如果没有的话,证明没有登录,所以毫不留情的 redirect("/login") 跳转登录页面

app.after_request

在响应(response)返回客户端之前执行 , 结束视图函数之后

@app.after_request
def foot_log(environ):
if request.path != "/login":
print("有客人访问了",request.path)
return environ

请求生命周期

无异常

顺序:be1 - be2 - be3 - 视图函数 - af3 - af2 - af1

有异常

顺序:be1 - be2 - af3 - af2 - af1

errorhandler

重定义错误信息

1.有参数的装饰器errorhandler(监听错误状态码 5xx 4xx Int)
2.所装饰的函数必须有一个形参来接受 errorMessage
# 监测错误状态码
@app.errorhandler(404) # 必须是int,而且必须是errorcode
def error(error_Message):
# 跳转到百度的错误页面
return redirect("https://www.baidu.com/search/error.html")

页面

app.template_global

1、用法:可以在全局范围的模板中使用这个函数, 而不用通过参数传到模板中
@app.template_global() # 记得加括号
# 这个方法每调用一次就需要传一次, 将他做成一个全局的就用这么麻烦了
def jiafa(a, b):
return int(a) + int(b)
2、在模板中使用
<h2>{{ jiafa(100, 30)}}</h2>

app.template_filter

1、用法
@app.template_filter()
def jianfa(a, b, c):
return a - b - c
2、在模板中这样使用
<h2>{{ 100|jianfa(100, 300) }}</h2>

Flask-特殊的装饰器的更多相关文章

  1. python flask route中装饰器的使用

    问题:route中的装饰器为什么感觉和平时使用的不太一样,装饰器带参数和不太参数有什么区别?被修饰的函数带参数和不带参数有什么区别? 测试1:装饰器不带参数,被修饰的函数也不带参数. def log( ...

  2. flask --- 03 .特殊装饰器, CBV , redis ,三方组件

    一.特殊装饰器(中间件) 1.before_request 在请求进入视图函数之前 @app.before_request def look(): 2. after_request 在结束视图函数之后 ...

  3. flask session,蓝图,装饰器,路由和对象配置

    1.Flask 中的路由   *endpoint - url_for 反向地址  *endpoint 默认是视图函数名  *methods 指定视图函数的请求方式,默认GET  defaults={& ...

  4. Flask系列06--(中间件)Flask的特殊装饰器 before_request,after_request, errorhandler

    一.使用 Flask中的特殊装饰器(中间件)方法常用的有三个 @app.before_request # 在请求进入视图函数之前 @app.after_request # 在请求结束视图函数之后 响应 ...

  5. flask(1.1)装饰器装饰多个视图函数出现的问题

    目录 1.装饰器装饰多个视图函数出现的问题 2.使用装饰器修复技术解决该问题 1.装饰器装饰多个视图函数出现的问题 代码实例: from flask import Flask, request, re ...

  6. flask框架-decorator装饰器

    调用包: from functools import wraps 装饰器其实就是一个函数:参数是一个函数,返回值是一个函数 1.装饰器使用是通过@符号,在函数的上面 2.装饰器中定义的函数,要使用*a ...

  7. flask模板语言,装饰器,路由及配置

    1.模板语言jinja2 Flask中默认的模板语言是Jinja2 1.0 模板传参 from flask import Flask,render_template app = Flask(__nam ...

  8. Flask 之装饰器有关

    - 先记住一句话:自定义python装饰器时一定要记住使用@functools.wraps(func)修饰wrapper - 在Flask中使用装饰器遇到AssertionError: View fu ...

  9. [Python自学] Flask框架 (1) (Flask介绍、配置、Session、路由、请求和响应、Jinjia2模板语言、视图装饰器)

    oldboy:s9day114 参考博客:https://www.cnblogs.com/wupeiqi/articles/7552008.html 一.Flask简介 1.安装Flask pip i ...

  10. 高逼格利器之Python闭包与装饰器

    生活在魔都的小明,终于攒够了首付,在魔都郊区买了一套房子:有一天,小明踩了狗屎,中了一注彩票,得到了20w,小明很是欢喜,于是想干脆用这20万来装修房子吧(decoration): 整个装修过程,小明 ...

随机推荐

  1. Spring MVC <context:annotation-config> 与 <context:component-scan>

    在MVC的配置文件中,二者常出现,功能相似.简单做个比较 <context:annotation-config> 用于激活应用上下文中已经注册的bean的注解,无论你的bean是通过什么方 ...

  2. HTTP协议探究(一):缓存

    一 复习与目标 1 复习 序章主要用WrieShark抓包HTTP报文 复习了TCP协议 讲述了TCP协议与HTTP之间的关系 HTTP1.1更新原因:HTTP1.0一次TCP连接只能发送一次HTTP ...

  3. 路由器WAN口IP显示为10、100、172开头,网络被电信联通等运营商做了NAT转发

    摘要:路由器WAN口IP显示为10.100.172开头,网络被电信联通等运营商做了NAT转发 ... 路由器WAN口IP显示为10.100.172开头的解决方法方法一:找电信(10000号)或者联通( ...

  4. MediaAPIController

    using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.D ...

  5. 【转】Fetch超时设置和终止请求

    原文链接:https://www.cnblogs.com/yfrs/p/fetch.html 1.基本使用 Fetch 是一个新的端获取资源的接口,用于替换笨重繁琐XMLHttpRequest.它有了 ...

  6. C# webserver实现短信发送(移动)

    近端时间接了个需求在原来的OA办公系统中添加一个发送短信功能.(既然需要发送短信那肯定要申请一个发送短信的账号,我这里是以移动mas为列子) c#的weserver需要选协议WS.其他的基本不用怎么填 ...

  7. JavaWeb-用过滤器修改请求的返回状态码

    问题: 客户SDK对接服务,默认只识别200和非200的请求状态码.需要修改当前应用的状态码(如将201转为200) 解决方案:通过扩展HttpServletResponseWrapper,获取到每个 ...

  8. 基于SAML2.0的SAP云产品Identity Authentication过程介绍

    SAP官网的架构图 https://cloudplatform.sap.com/scenarios/usecases/authentication.html 上图介绍了用户访问SAP云平台时经历的Au ...

  9. 【Day3】3.提取商城分类结构

    import re with open('index.html','r',encoding='utf-8') as f: html = re.sub('\n','',f.read()) section ...

  10. PAT Basic 1082 射击比赛 (20 分)

    本题目给出的射击比赛的规则非常简单,谁打的弹洞距离靶心最近,谁就是冠军:谁差得最远,谁就是菜鸟.本题给出一系列弹洞的平面坐标(x,y),请你编写程序找出冠军和菜鸟.我们假设靶心在原点(0,0). 输入 ...