装饰器 以及 django 中的应用
-
装饰器本质上是一个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