Django之CSRF以及CBV补充

Posted nayike

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django之CSRF以及CBV补充相关的知识,希望对你有一定的参考价值。

 

 

1.CSRF

  a.基本应用

    form表单中添加

    {% csrf_token %}

  b.全栈禁用

    # ‘django.middleware.csrf.CsrfViewMiddleware‘,

  c. 局部禁用
            ‘django.middleware.csrf.CsrfViewMiddleware‘,

    from django.views.decorators.csrf import csrf_exempt

    @csrf_exempt

    def  csrf1(request):

      if request.method == ‘GET‘:

        return render(request,‘csrf1.html‘)

      else:

        return HttpResponse(‘ok‘)

 

  d.局部使用

  # ‘django.middleware.csrf.CsrfViewMiddleware‘,

  from django.views.decorators.csrf  import csrf_exempt,csrf_protect

 

  @csrf_protect

  def csrf1(request):

    if request.method == "GET":

      return render(request,‘csrf1.html‘)

    else:

      return HttpResponse(‘OK‘)

 

  c.特殊CBV

    form django.views import View

    from django.utls.decorators import method_decorator

    @method_decorator(csrf_protect,name=‘dispatch‘)

    class Foo(View):

      def get(self,request):

        pass

      def post(self,request):

        pass

 

 

 

  PS:CBV中添加装饰器

    def wrapper(func):

      def inner(*args,**kwargs):

        return func(*args,**kwargs)

      return inner

    #1.指定方法上添加装饰器

      class Foo(View):

        @method_decorator(wrapper)

        def get(self,request):

          pass

        def post(self,request):

          pass

    2.在类上添加

      @method_decorator(wrapper,name=‘dispatch‘)

      class Foo(View):

        def get(self,request):
          pass

        def post(self,request):

          pass

    

    

 

以上是关于Django之CSRF以及CBV补充的主要内容,如果未能解决你的问题,请参考以下文章

Django CBV装饰器 中间件 auth模块 CSRF跨站请求

django补充CBV和FBV模式

使用Ajax (put delete ) django原生CBV 出现csrf token解决办法

Python菜鸟之路:Django 路由补充FBV和CBV

django 之csrfauth模块及settings源码插拔式设计

Django 之 CBV