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
})