django的rest framework框架----認(rèn)證、權(quán)限、節(jié)流、版本、解析

setting中的全局配置:

當(dāng)一些地方不需要一些功能時,只需在類視圖中設(shè)一個空值即可,例如取消認(rèn)證,則在視圖類中寫入 authentication_classes = [] .

REST_FRAMEWORK = {
    # 認(rèn)證,設(shè)置匿名用戶['這里是自定義類的路徑']
    'DEFAULT_AUTHENTICATION_CLASSES':['myutils.Authtication.MyAuthtication'],
    'UNAUTHENTICATED_USER': lambda :'匿名用戶',
    'UNAUTHENTICATED_TOKEN':lambda :'123456',
    # 權(quán)限設(shè)置
    'DEFAULT_THROTTLE_CLASSES':['myutils.Throttling.VisitThrottle'],
    # 節(jié)流:設(shè)置訪問頻率
    'DEFAULT_PERMISSION_CLASSES':['myutils.Permission.MyOrderPermission'],
    'DEFAULT_THROTTLE_RATES':{
        'myscope':'3/m', #基于IP
        "user_scope": "5/m"  #基于用戶
    },
    #版本
    REST_FRAMEWORK = {
        'VERSION_PARAM':'version',   #參數(shù)
        'DEFAULT_VERSION':'v1',   #默認(rèn)版本
        'ALLOWED_VERSIONS':['v1','v2'],  #允許版本
    "DEFAULT_VERSIONING_CLASS": "rest_framework.versioning.URLPathVersioning",
    #解析
    'DEFAULT_PARSER_CLASSES':['rest_framework.parsers.JSONParser','rest_framework.parsers.FormParser']
}

認(rèn)證

需要自定義一個認(rèn)證類,最好單獨(dú)建一個文件存放,方便管理

from rest_framework.authentication import BasicAuthentication
from rest_framework.exceptions import AuthenticationFailed
class MyAuthtication(BasicAuthentication):
    #這個方法必須實(shí)現(xiàn),里面是一些認(rèn)證邏輯
    def authenticate(self, request):
        token = request._request.GET.get("token")
        token_obj = UserToken.objects.filter(token=token).first()
        if not token_obj:
            raise AuthenticationFailed("用戶認(rèn)證失敗")
        # 在rest framework內(nèi)部會將這兩個字段賦值給request,以供我們后續(xù)操作使用
        return (token_obj.user, token_obj)

權(quán)限

同認(rèn)證一樣,自定義一個類

from rest_framework.authentication import BasicAuthentication
class MyOrderPermission(BasicAuthentication):
    def has_permission(self,request,view):
        #關(guān)于判定權(quán)限的邏輯,返回True表示有權(quán)限訪問,返回False表示沒有權(quán)限訪問
        if request.user.user_type != 3:
            return False
        return True

節(jié)流

(同上)

from rest_framework.throttling import BaseThrottle,SimpleRateThrottle
class VisitThrottle(SimpleRateThrottle):
    scope = "user_scope"
    #這里和setting中的對應(yīng)基于IP或用戶
    def get_cache_key(self, request, view):
        return self.get_ident(request)

版本

如果使用URLPathVersioning,路由格式如下
url(r"^(?P<version>[v1|v2]+)/version/",VersionView.as_view(),name='vvvv')

    def get(self,request,*args,**kwargs):
        version = request.version
        obj = request.versioning_scheme
        # 反向生產(chǎn)url地址
        from django.urls import reverse
        url1 = obj.reverse(viewname='order',request=request)
        return Response({
            "msg":"版本",
            "version": version,
            "url1":url1
        })

解析

進(jìn)行全局設(shè)置后,用的時候只需要用request.data就可以自動解析數(shù)據(jù)為Json格式
作用就是服務(wù)端接收客戶端傳過來的數(shù)據(jù),把數(shù)據(jù)解析成自己想要的數(shù)據(jù)類型的過程

class UserInfoView(APIView):
    def post(self,request,*args,**kwargs):
        data = request.data
        print(data)
        return Response({
            'data':data
        })
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容