装饰器本质上是一个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_protectcsrf_exempt
给视图加上装饰器后,当前的视图不需要CSRF校验 csrf_protect
给视图加上装饰器后,当前的视图需要CSRF校验 确保浏览器带有cookie的两种方式:
> 在form表单内加入 {% csrf_token %}
> 不使用{% csrf_token %},导入
from django.views.decorators.csrf import ensure_csrf_cookie
将
ensure_csrf_cookie
以装饰器形式加在视图上,保证返回的相应有cookie