django rest framework 中的 GenericAPIView 的属性和方法的相应功能

该文章详细介绍了在DjangoRESTFramework中创建一个用于管理User模型的GenericAPIView。视图包括GET和POST方法,GET方法处理查询集的过滤和分页,POST方法用于创建新用户。此外,它还涉及了权限设置,使用IsAdminUser确保只有管理员可以访问。
摘要由CSDN通过智能技术生成
  • 属性:
    • queryset - 用于从这个视图返回对象的查询集。通常,你必须设置这个属性,或者重写get_queryset ()方法。如果你重写了一个视图方法,重要的是你调用get_queryset ()而不是直接访问这个属性,因为queryset只会被评估一次,然后缓存给所有后续的请求。
    • serializer_class - 用于验证和反序列化输入,以及序列化输出的序列化器类。通常,你必须设置这个属性,或者重写get_serializer_class ()方法。
    • lookup_field - 用于从URL中获取对象的关键字参数的名称。默认是’pk’。
    • lookup_url_kwarg - 用于从URL中获取对象的关键字参数的名称。如果没有设置,将使用lookup_field作为默认值。
    • filter_backends - 用于过滤查询集的过滤器后端列表。
    • pagination_class - 用于分页查询集的分页器类。
  • 方法:
    • get_object (self) - 返回视图所代表的对象。如果没有找到对象,将抛出一个404错误。
    • get_queryset (self) - 返回视图所使用的查询集。默认返回queryset属性的值,如果没有设置,则抛出一个异常。
    • get_serializer (self, args, **kwargs) - 返回一个序列化器实例。默认使用serializer_class属性创建一个序列化器,并传递给它args和**kwargs作为参数。
    • get_serializer_class (self) - 返回视图所使用的序列化器类。默认返回serializer_class属性的值,如果没有设置,则抛出一个异常。
    • filter_queryset (self, queryset) - 对给定的查询集应用任何过滤器后端。默认使用filter_backends属性中指定的过滤器后端。
    • paginate_queryset (self, queryset) - 对给定的查询集应用分页。默认使用pagination_class属性中指定的分页器类。
    • get_paginated_response (self, data) - 返回一个分页后的响应对象。默认使用pagination_class属性中指定的分页器类的get_paginated_response ()方法。
from django.contrib.auth.models import User
from myapp.serializers import UserSerializer
from rest_framework import generics
from rest_framework.permissions import IsAdminUser

class UserList(generics.GenericAPIView):
    queryset = User.objects.all()
    serializer_class = UserSerializer
    permission_classes = [IsAdminUser]

    def get(self, request, *args, **kwargs):
        # 获取查询集并过滤、分页
        queryset = self.filter_queryset(self.get_queryset())
        page = self.paginate_queryset(queryset)
        if page is not None:
            # 如果有分页,返回分页后的响应
            serializer = self.get_serializer(page, many=True)
            return self.get_paginated_response(serializer.data)

        # 如果没有分页,返回全部数据
        serializer = self.get_serializer(queryset, many=True)
        return Response(serializer.data)

    def post(self, request, *args, **kwargs):
        # 获取并验证输入数据
        serializer = self.get_serializer(data=request.data)
        serializer.is_valid(raise_exception=True)
        # 创建并保存用户对象
        user = serializer.save()
        # 返回创建成功的响应
        return Response(serializer.data, status=status.HTTP_201_CREATED)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值