Django ModelViewSet 认证

一、Django ModelViewSet简介

在 Django REST framework 中,ModelViewSet 是一种可以将常见的列表、详细视图、创建、更新、删除等操作组合起来的视图。这样可以帮助我们减少代码量,使代码结构更加清晰。

以下是一个简单的例子:

python 复制代码
from rest_framework import viewsets
from .models import MyModel
from .serializers import MyModelSerializer


class MyModelViewSet(viewsets.ModelViewSet):
    queryset = MyModel.objects.all()
    serializer_class = MyModelSerializer

上述代码中,我们定义了一个 MyModelViewSet,继承自ModelViewSet,它代表了对MyModel模型的基本 CRUD 操作。

二、Django ModelViewSet 认证设置

Django REST framework 提供了一种简单而灵活的方式来设置API的认证规则,通过在ModelViewSet中使用authentication_classes属性,可以设置认证方式。

下面是一个设置的简单示例:

python 复制代码
from rest_framework import viewsets
from rest_framework.authentication import TokenAuthentication
from .models import MyModel
from .serializers import MyModelSerializer


class MyModelViewSet(viewsets.ModelViewSet):
    queryset = MyModel.objects.all()
    serializer_class = MyModelSerializer
    authentication_classes = [TokenAuthentication]

上述代码设置了 Token 认证方式,用户请求 API 时需在 Header 中带有 Token。

三、Django 默认认证设置

如果你的项目中大部分的 API 都使用相同的认证方式,那么你可以在项目设置中进行全局的认证设置,这样可以避免在每个视图中都设置认证方式。

下面是一个设置的简单示例:

python 复制代码
# settings.py
REST_FRAMEWORK = {
    'DEFAULT_AUTHENTICATION_CLASSES': [
        'rest_framework.authentication.TokenAuthentication',
    ]
}

上述代码设置了项目默认的认证方式为 Token 认证。

四、Django 自定义认证

除了 Django REST framework 提供的认证方式,你也可以自定义认证方式,只需继承BaseAuthentication类,重写authenticate方法。

下面是一个自定义认证的简单示例:

python 复制代码
from rest_framework import authentication
from rest_framework import exceptions


class MyAuthentication(authentication.BaseAuthentication):
    def authenticate(self, request):
        token = request.META.get('HTTP_MYTOKEN')
        if not token:
            return None

        if token != 'my_token':
            raise exceptions.AuthenticationFailed('认证失败!')

        return (token, None)

在这个示例中,我们创建了一个名为 MyAuthentication 的自定义认证类。在 authenticate 方法中,我们检查 header 中是否包含 MYTOKEN ,如果不存在则返回 None,让 Django REST framework 使用其他的认证方式。如果存在,但值不等于 'my_token',则抛出认证失败的异常。

总结起来,Django REST framework 提供了强大而灵活的认证设置,使我们可以在项目中轻松地处理 API 的认证问题。

相关推荐
u0103731062 小时前
Django异步执行任务django-background-tasks
后端·python·django
Edward-tan14 小时前
【玩转全栈】—— Django 连接 vue3 保姆级教程,前后端分离式项目2025年4月最新!!!
后端·python·django
吾非善类15 小时前
Django使用WebSocket
后端·python·django
码界筑梦坊1 天前
基于Django的二手交易校园购物系统
大数据·后端·python·信息可视化·django
l软件定制开发工作室1 天前
Django REST Framework系列教程(6)——认证详解与Token认证
django
唐古乌梁海2 天前
【Django】教程-9-登录+退出
django
兔子的洋葱圈2 天前
【django】3 (django路由) 路由配置和反向解析
后端·python·django
零一先生【Z】2 天前
一、简单的 Django 服务
后端·python·django
月小水长2 天前
Django 使用 matplotlib 遇到 RuntimeError: main thread is not in main loop 解决办法
python·django·matplotlib·thread·anr
南城猿3 天前
Pycharm中Django框架使用{% load static %}模板,HTML报错
ide·pycharm·django