flask类装饰器

from flask import Flask,request,views
from functools import wraps

app = Flask(__name__)

#自定义登录装饰器
def login_required(func):
    @wraps(func)
    def wapper(*args,**kwargs):
        username = request.args.get(‘username‘)
        if username and username == ‘xiaowu‘:
            return func(*args,**kwargs)
        else:
            return ‘请先登录‘
    return wapper

@app.route(‘/‘)
def index():
    return ‘网站首页‘

@app.route(‘/setting/‘)
@login_required
def setting():
    return ‘这是设置页面‘

#类视图怎么使用装饰器
class ProfileView(views.View):

    decorators = [login_required]
    def dispatch_request(self):
        return "个人中心页面"

app.add_url_rule(‘/profile/‘,endpoint=‘profile‘,view_func=ProfileView.as_view(
    ‘profile‘
))
if __name__ == ‘__main__‘:
    app.run(debug=True)

原文地址:https://www.cnblogs.com/wuheng-123/p/9684065.html

时间: 2024-11-09 03:08:08

flask类装饰器的相关文章

第七章 Flask——特殊装饰器

第七章 Flask--特殊装饰器 一.@app.template_filter() 二.@app.template_global() 三.@app.errorhandler 四.@app.errorhandler 五.@app.after_request 一.@app.template_filter() 二.@app.template_global() 三.@app.errorhandler 四.@app.errorhandler 五.@app.after_request 原文地址:https:

类装饰器

在理解类装饰器之前,先回忆一下有关装饰器的知识.装饰器本质上就是一个函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外的功能,装饰器的返回值也是一个函数对象(函数的引用). __call__方法 一个对象是否可调用,看其中是否实现了__call__方法.例如,类的对象是不可调用的,因为其中没有实现__call__方法.如果我们在一个类中定义了__call__方法,那么这个类对象将变得可调用.只要某个对象定义了__call__()方法,那么这个对象就是callable的. 类中没有实现_

Python之路(十二):描述符,类装饰器,元类

python基础之面向对象(描述符.类装饰器及元类) 描述符 描述符(__get__,__set__,__delete__)   # 这里着重描述了python的底层实现原理 1. 描述符是什么:描述符本质就是一个新式类,在这个新式类中,至少实现了__get__(),__set__(),__delete__()中的一个,这也被称为描述符协议. __get__():调用一个属性时,触发 __set__():为一个属性赋值时,触发 __delete__():采用del删除属性时,触发 1 class

python 描述符 上下文管理协议 类装饰器 property metaclass

1.描述符 #!/usr/bin/python env # coding=utf-8 # 数据描述符__get__ __set__ __delete__ ''' 描述符总结 描述符是可以实现大部分python类特性中的底层魔法,包括@classmethod,@staticmethd,@property甚至是__slots__属性 描述符是很多高级库和框架的重要工具之一,描述符通常是使用到装饰器或者元类的大型框架中的一个组件 注意事项: 一 描述符本身应该定义成新式类,被代理的类也应该是新式类 二

函数装饰器和类装饰器实现单例类

单例类,指的是这个类只能创建一个实例,创建完成后,其他类实例都无法再创建.今天我们来看一下,使用函数装饰器和类装饰器怎么实现这种特殊一点的类. 函数装饰器实现 装饰器算是类里面比较难的内容之一,但是实际上它的思想并不复杂.简单点说,就是在你原来内容的基础上,在外面给你加点东西,实现类似装饰的效果.但是它是怎么实现的呢?一般来说,都是通过拦截函数调用来实现的,比如:用装饰器装饰函数的时候,它拦截函数调用,装饰类的时候,它拦截类实例的创建调用,即拦截类初始化__init__函数.知道这个原理以后,我

8.python之面相对象part.8(类装饰器)

下面是一个对类使用装饰器的一个示例,主要目的就是给一个定义好的类通过装饰器的形式去临时增加属性或者方法. def add_property(**kwargs): def deco(obj): for key,value in kwargs.items(): setattr(obj,key,value) return obj return deco @ add_property(a=1,b=2,c=3) class test: pass t1 = test() print test.a print

python_类装饰器

一.定义装饰器就是一个给对象添加额外功能的函数,其本质是函数.它的基本构造:高阶函数+函数嵌套+闭包.基础知识讲解详见:http://blog.51cto.com/10836356/2095118二.简单类的装饰器我们先看简单的类的装饰器,如果我们需要给任意一个类添加一个打印功能,即:没当操作这个类时,就打印"定义了一个装饰类函数",见下图:@Decorator #相当于执行 School = Decorator(School)注释内容若有疑问,请参考:http://blog.51ct

Flask 之装饰器有关

- 先记住一句话:自定义python装饰器时一定要记住使用@functools.wraps(func)修饰wrapper - 在Flask中使用装饰器遇到AssertionError: View function mapping is overwriting an existing... - 报错的大概意思就是存在相同的view,在flask中,如果定义了两个相同函数名的view,就会报这种报这种错误,例如: - 但是上例中的两个函数名分别是index和course,是不相同的,为什么会报这种错

python 类装饰器

1 装饰器无参数 class tracer: def __init__(self,func): self.calls = 0 self.func = func def __call__(self,*args): self.calls += 1 print('call %s to %s' %(self.calls, self.func.__name__)) self.func(*args) @tracer def spam(a, b, c): print(a + b + c) spam(1,2,3