rest-framework之权限组件

rest-framework之权限组件

一 权限简介

只用超级用户才能访问指定的数据,普通用户不能访问,所以就要有权限组件对其限制

二 局部使用

复制代码

from rest_framework.permissions import BasePermission
class UserPermission(BasePermission):
  message = '不是超级用户,查看不了'
  def has_permission(self, request, view):
      # user_type = request.user.get_user_type_display()
      # if user_type == '超级用户':
      user_type = request.user.user_type
      print(user_type)
      if user_type == 1:
          return True
      else:
          return False
class Course(APIView):
  authentication_classes = [TokenAuth, ]
  permission_classes = [UserPermission,]

  def get(self, request):
      return HttpResponse('get')

  def post(self, request):
      return HttpResponse('post')

复制代码

局部使用只需要在视图类里加入:

permission_classes = [UserPermission,]

三 全局使用

REST_FRAMEWORK={
  "DEFAULT_AUTHENTICATION_CLASSES":["app01.service.auth.Authentication",],
  "DEFAULT_PERMISSION_CLASSES":["app01.service.permissions.SVIPPermission",]
}

四 源码分析

复制代码

def check_permissions(self, request):
  for permission in self.get_permissions():
      if not permission.has_permission(request, self):
          self.permission_denied(
              request, message=getattr(permission, 'message', None)
              )

复制代码

self.get_permissions()

def get_permissions(self):
    return [permission() for permission in self.permission_classes]

权限类使用顺序:先用视图类中的*权限类*,再用settings里配置的*权限类*,最后用默认的*权限类*

posted @   mjth  阅读(33)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
点击右上角即可分享
微信分享提示