Django CBV视图解决csrf认证

本文介绍在Django中如何使用两种不同的方式创建一个不进行CSRF验证的Class-Based View,通过装饰器和方法装饰器实现,适用于HTTP请求的GET、POST、PUT和DELETE方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

urls.py

from django.conf.urls import url
from appxx import views

urlpatterns = [
    url(r"^$", views.TestView.as_view()),
]

views.py

from django.views import View
from django.shortcuts import HttpResponse
from django.views.decorators.csrf import csrf_exempt
from django.utils.decorators import method_decorator

第一种方式:

class TestView(View):
@method_decorator(csrf_exempt)
def dispatch(self, request, *args, **kwargs): return super(TestView, self).dispatch(request, *args, **kwargs) def get(self, request, *args, **kwargs): return HttpResponse("GET") def post(self, request, *args, **kwargs): return HttpResponse("POST") def put(self, request, *args, **kwargs): return HttpResponse("PUT") def delete(self, request, *args, **kwargs): return HttpResponse("DELETE")

第二种方式:

@method_decorator(csrf_exempt, name="dispatch")
class TestView(View):

    def get(self, request, *args, **kwargs):
        return HttpResponse("GET")

    def post(self, request, *args, **kwargs):
        return HttpResponse("POST")

    def put(self, request, *args, **kwargs):
        return HttpResponse("PUT")

    def delete(self, request, *args, **kwargs):
        return HttpResponse("DELETE")

 

转载于:https://www.cnblogs.com/believepd/p/10277412.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值