装饰器本质上是一个Python函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象。它经常用于有切面需求的场景,比如:插入日志、性能测试、事务处理、缓存、权限校验等场景。装饰器是解决这类问题的绝佳设计,有了装饰器,我们就可以抽离出大量与函数功能本身无关的雷同代码并继续重用。
# 简单的 装饰器
from functools import wraps # 装饰器修复
def wrapper(func):
  @wraps(func)  # 装饰器修复
    def inner(*args, **kwargs):
        # 执行函数前的操作
        ret = func(*args, **kwargs)
        # 执行函数后的操作
        return ret
    return inner
@wrapper  # 加装饰器
def func():
    print("Hello Word!")
# 有开关的 装饰器
flag = True    #  通过 T 或 F  判断是否使用装饰器
def outher(flag):
    def wrapper(func):
      @wraps(func)  # 装饰器修复
        def inner(*args, **kwargs):
          if flag:
              return func(*args, **kwargs)
             # 执行函数前的操作
          ret = func(*args, **kwargs)
          # 执行函数后的操作
          return ret
        return inner
    return wrapper
@outher(flag)
def func():
    print("Hello Word!")给CBV 加装饰器 --->>> 给 类 及 方法 加装饰器
from django.views import View
from django.utils.decorators import method_decorator
import time
# 计算执行时间
def timer(func):
    def inner(request, *args, **kwargs):
        start = time.time()
        ret = func(request, *args, **kwargs)
        end = time.time()
        print(‘时间:{}‘.format(end - start))
        return ret
    return inner
给类加装饰器 要 制定 name=‘方法名‘ 
# @method_decorator(timer, name=‘post‘)
# @method_decorator(timer, name=‘get‘)
class AddPublisher(View):
    # http_method_names = [‘get‘]
    @method_decorator(timer)
    def get(self, request):
        return render(request, ‘***.html‘)
    @method_decorator(timer)
    def post(self, request):
        return self.get(request)Django 中自带的装饰器
from django.views.decorators.csrf import csrf_exempt, csrf_protect
csrf_exempt
给视图加上装饰器后,当前的视图不需要CSRF校验
csrf_protect
给视图加上装饰器后,当前的视图需要CSRF校验
确保浏览器带有cookie的两种方式:
    > 在form表单内加入 {% csrf_token %}
    > 不使用{% csrf_token %},导入
    from django.views.decorators.csrf import ensure_csrf_cookie
    将
    ensure_csrf_cookie
    以装饰器形式加在视图上,保证返回的相应有cookie原文:https://www.cnblogs.com/zhang-zi-yi/p/10181609.html