django基础之初始化 views视图 (6)
user/views.py#
from django.http import HttpResponse
from django_filters.rest_framework import DjangoFilterBackend
from rest_framework import viewsets
from rest_framework.authentication import BasicAuthentication, SessionAuthentication
from rest_framework.decorators import action
from rest_framework.filters import OrderingFilter
from rest_framework.permissions import AllowAny, IsAdminUser, IsAuthenticated, IsAuthenticatedOrReadOnly
from rest_framework.response import Response
from rest_framework.throttling import UserRateThrottle
from rest_framework.pagination import PageNumberPagination
from rest_framework.views import APIView
from rest_framework.permissions import BasePermission, SAFE_METHODS
from user.models import User
from user.serializes import UserSerializer
# 需要认证才能访问的视图
def index(request):
return HttpResponse("hello python!!!!")
# 分页(局部):自定义分页器 局部
class PageNum(PageNumberPagination):
# 查询字符串中代表的每页返回数量的参数名,默认:None
page_size_query_param = 'page_size'
# 查询字符串中代表页码的参数名,有默认值:page
# page_query_param='page'
# 一页中最多的结果条数
max_page_size = 2
# 自定义权限(局部)
class MyPermission(BasePermission):
def has_permission(self, request, view):
print(view.kwargs.get("pk"), request.user.id)
'''判断用户对模型有没有访问权'''
# 任何用户对使用此权限类的视图都有访问权限
print(request)
if request.user.is_superuser:
# 管理员对用户模型有访问权
return True
elif view.kwargs.get('pk') == str(request.user.id):
# 携带的id和用户的id相同时有访问权
return True
return False
def has_object_permission(self, request, view, obj):
'''获取单个数据时,判断用户对某个数据对象是否有访问权限'''
if request.user.id == obj.id:
return True
return False
class UserViewSet(viewsets.ModelViewSet):
'''完成产品的增删改查'''
queryset = User.objects.all()
serializer_class = UserSerializer # 优先使用get_serializer_class 返回的序列化器
# 1.认证:自定义认证类,自定义会覆盖全局配置
authentication_classes = (BasicAuthentication, SessionAuthentication)
# 2.权限:自定义权限类
# permission_classes = (MyPermission)
# 3.分页:自定义分页器 覆盖全局配置
pagination_class = PageNum
# 4.限流:自定义限流类
throttle_classes = [UserRateThrottle]
# 5.过滤:指定过滤方法类,排序方法类,一个或多个
filter_backends = (DjangoFilterBackend, OrderingFilter) # 同时支持过滤和排序
# 5.1 指定排序字段 不设置,排序功能不起效
ordering_fields = ('date_joined', 'id') # ?ordering=-id
# 5.2 指定过滤字段,不设置,过滤功能不起效
filter_fields = ('username', 'phone', 'is_active') # ?username=tom&phone=&is_active=true
# 根据不同的请求 获取不同的序列化器
def get_serializer_class(self):
if self.action == 'unactived':
pass
else:
return UserSerializer
作者:就学45分钟
出处:https://www.cnblogs.com/tjw-bk/p/13746231.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
分类:
Django-项目开发
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了