DRF权限控制

DRF权限控制

前提:你的用户表中需要有权限的字段,下面的权限的字段是user_type

1.写一个权限控制类
from rest_framework import exceptions
from app01 import models
from rest_framework.permissions import BasePermission
class Userpermission(Basepermission):
    #使放回的错误信息变成你想显示的信息
    massage = '您没有权限!'
    #注意这里的方法名固定
    def has_permission(self, request, view):
        user_type = request.user.user_type
        if user_type == 2:
            #返回True表示验证通过
            return True
        else:
            #返回False表示验证不通过
            return False
2.局部使用

​ 在视图类中添加

permission_classes = [AuthAPI.UserPermission,]

例如:

class Books(APIView):
    permission_classes = [AuthAPI.UserPermission,]
    def get(self, request):
        books = models.Book.objects.all()
        books_res = BooksDRF(books, many=True)
        authors = models.Author.objects.all()
        authors_res = AuthorsDRF(instance=authors,many=True)
        response = {'status':200,'msg':'查询成功!','books':books_res.data,'authors':authors_res.data}
        return JsonResponse(response, safe=False)
3.全局使用

​ 在setting中配置

REST_FRAMEWORK = {
    'DEFAULT_PERMISSION_CLASSES': ['app01.AuthAPI.UserPermission']
}
4.局部禁用(与全局使用配合使用)

​ 在要禁用的视图函数中添加

permission_classes = []

例如:

class Books(APIView):
    permission_classes = []
    def get(self, request):
        books = models.Book.objects.all()
        books_res = BooksDRF(books, many=True)
        authors = models.Author.objects.all()
        authors_res = AuthorsDRF(instance=authors,many=True)
        response = {'status':200,'msg':'查询成功!','books':books_res.data,'authors':authors_res.data}
        return JsonResponse(response, safe=False)

转载于:https://www.cnblogs.com/jianhaozhou/p/10114849.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值