python (django) 3. 权限 permission

1. api/permission.py

# -*- coding: utf8 -*-


class GradeOnePermission(object):

    def has_permission(self, request, view):
        grade = request.user.grade
        print(request.user)
        print(grade)
        if grade == 1:
            return True
        else:
            return False

2. api/views.py

from api.authenticate import StudentAuthenticate
from api.permission import GradeOnePermission


class TokenView(GenericViewSet):

    # authentication_classes = []
    permission_classes = [GradeOnePermission]
    parser_classes = [JSONParser, ]

    def get(self, request, *args, **kwargs):
        name = request.query_params.get('name')
        try:
            stu = Student.objects.get(name=name)
        except Student.DoesNotExist:
            raise ParseError(_('Student does not include this name'))

        token = stu.token.token
        res = dict()
        res['code'] = 200
        res['name'] = name
        res['token'] = token
        logger.info(pformat(res))

        return Response(data=res, status=status.HTTP_200_OK)

3. settings.py

REST_FRAMEWORK = {
    'DEFAULT_AUTHENTICATION_CLASSES':  ['api.authenticate.StudentAuthenticate'],
    'DEFAULT_PERMISSOIN_CLASSES': ['api.permission.GradeOnePermisson'],
}

4. postman

(1)

url: http://127.0.0.1:8011/api/v1/auth/

method: post

data: {
    "name": "student2",
    "password": "password1",
    "grade": 2
}

return:

{
    "code": 200,
    "name": "student2",
    "token": "950f0ed2b4f164900f996bf1c6bf225c",
    "msg": "创建成功"
}

(2)

url: http://127.0.0.1:8011/api/v1/token/?name=student2&token=950f0ed2b4f164900f996bf1c6bf225c

method: get

return:

{
    "detail": "You do not have permission to perform this action."
}

(3)

url: http://127.0.0.1:8011/api/v1/token/?name=student1&token=dbfa6b230b9ca22302a00ea918346f86

method: get

return:

{
    "code": 200,
    "name": "student1",
    "token": "dbfa6b230b9ca22302a00ea918346f86"
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值