版本控制: 方法一 1 127.0.0.1/course/?version=v100000 用from rest_framework.versioning import QueryParameterVersioning 在視圖類裏: versioning_class=QueryParameterVersioning(**再也不是列表) 在setting裏配置: REST_FRAMEWORK={ 'VERSION_PARAM':'version', 'DEFAULT_VERSION':'v2', 'ALLOWED_VERSIONS':['v1','v2'] } 取: 視圖類裏: request.version 方法二 127.0.0.1/v1/course/ 用from rest_framework.versioning import URLPathVersioning 在視圖類裏: versioning_class=URLPathVersioning**再也不是列表) 在setting裏配置: REST_FRAMEWORK={ 'VERSION_PARAM':'version', 'DEFAULT_VERSION':'v2', 'ALLOWED_VERSIONS':['v1','v2'] } 取: 視圖類裏: request.version
from rest_framework.renderers import
顯示json格式:JSONRenderer 訪問URL: http://127.0.0.1:8000/test/?format=json http://127.0.0.1:8000/test.json http://127.0.0.1:8000/test/ 默認顯示格式:BrowsableAPIRenderer(能夠修改它的html文件) 訪問URL: http://127.0.0.1:8000/test/?format=api http://127.0.0.1:8000/test.api http://127.0.0.1:8000/test/ 表格方式:AdminRenderer 訪問URL: http://127.0.0.1:8000/test/?format=admin http://127.0.0.1:8000/test.admin http://127.0.0.1:8000/test/ form表單方式:HTMLFormRenderer 訪問URL: http://127.0.0.1:8000/test/?format=form http://127.0.0.1:8000/test.form http://127.0.0.1:8000/test/
from rest_framework import serializers Serializers class BookSerializer1(serializers.ModelSerializer): class Meta: model=models.Book # fields="__all__" exclude=('authors',) from rest_framework.pagination import PageNumberPagination # 一 基本使用:url=url=http://127.0.0.1:8000/pager/?page=2&size=3,size無效 class Pager(APIView): def get(self,request,*args,**kwargs): # 獲取全部數據 ret=models.Book.objects.all() # 建立分頁對象 page=PageNumberPagination() # 在數據庫中獲取分頁的數據 page_list=page.paginate_queryset(ret,request,view=self) # 對分頁進行序列化 ser=BookSerializer1(instance=page_list,many=True) return Response(ser.data) # 二 自定製 url=http://127.0.0.1:8000/pager/?page=2&size=3 # size=30,無效,最多5條 class Mypage(PageNumberPagination): page_size = 2 page_query_param = 'page' # 定製傳參 page_size_query_param = 'size' # 最大一頁的數據 max_page_size = 5 class Pager(APIView): def get(self,request,*args,**kwargs): # 獲取全部數據 ret=models.Book.objects.all() # 建立分頁對象 page=Mypage() # 在數據庫中獲取分頁的數據 page_list=page.paginate_queryset(ret,request,view=self) # 對分頁進行序列化 ser=BookSerializer1(instance=page_list,many=True) # return Response(ser.data) # 這個也是返回Response對象,可是比基本的多了上一頁,下一頁,和總數據條數(瞭解便可) return page.get_paginated_response(ser.data)
# http://127.0.0.1:8000/pager/?offset=4&limit=3 from rest_framework.pagination import LimitOffsetPagination # 也能夠自定製,同簡單分頁 class Pager(APIView): def get(self,request,*args,**kwargs): # 獲取全部數據 ret=models.Book.objects.all() # 建立分頁對象 page=LimitOffsetPagination() # 在數據庫中獲取分頁的數據 page_list=page.paginate_queryset(ret,request,view=self) # 對分頁進行序列化 ser=BookSerializer1(instance=page_list,many=True) # return page.get_paginated_response(ser.data) return Response(ser.data)
from rest_framework.pagination import CursorPagination # 看源碼,是經過sql查詢,大於id和小於id class Pager(APIView): def get(self,request,*args,**kwargs): # 獲取全部數據 ret=models.Book.objects.all() # 建立分頁對象 page=CursorPagination() page.ordering='nid' # 在數據庫中獲取分頁的數據 page_list=page.paginate_queryset(ret,request,view=self) # 對分頁進行序列化 ser=BookSerializer1(instance=page_list,many=True) # 能夠避免頁碼被猜到 return page.get_paginated_response(ser.data)