1 数据解析器

1 什么是解析器

相当于request 中content-type

对方传什么类型的数据,我接受什么样的数据;怎样解析

无论前面传的是什么数据,都可以解开

例如:django不能解析json数据,restfrmaework可以解析

django只能解开,urlcode的数据

添加一本书籍,传json数据

2 5种解析器

j

支持4个

解析二进制文件用

常用的2个解析器

默认使用3个

3 JSONParser解析器

反序列化 json--dict

如何引用,

走我的,只能解析一种JSON

test

现在只能解析1 中 json

4 FormParser解析器

添加form解析器

5 Code与笔记

笔记

7 解析器-----数据解析器
from rest_framework.parsers import JSONParser,FormParser,MultiPartParser,FileUploadParser
parser_classes = [JSONParser,FormParser]

view

from rest_framework.parsers import JSONParser
from rest_framework.parsers import FormParser class BookView(APIView):
# authentication_classes = [TokenAuth,] # 认证组件
# permission_classes =[] # 权限组件
# throttle_classes = [] # 频率组件 # parser_classes = [JSONParser]
parser_classes = [JSONParser,FormParser] def get(self,request):
book_list = Book.objects.all()
bs = BookModelSerializers(book_list,many=True,context={'request':request})
return Response(bs.data) # Response继承HttpResponse def post(self,request):
# post请求的数据
print(request.data)
# self.dispatch
bs = BookModelSerializers(data=request.data,context={'request':request})
if bs.is_valid():
print(bs.validated_data)
bs.save() # create方法
return Response(bs.data)
else:
return Response(bs.errors)

2 url控制

1.针对 视图3 viewset

最后一种方式,有4条url

4条url

url 有重复的内容,如何优化

2.官方文档

注册下

自动生成url的路径

3. 如何生成4条url

这4条是帮我生成的

test

4.code

路由控制
针对:
url(r'^authors/$', views.AuthorModelView.as_view({"get":"list","post":"create"}),name="author"),
url(r'^authors/(?P<pk>\d+)/$', views.AuthorModelView.as_view({"get":"retrieve","put":"update","delete":"destroy"}),name="detailauthor"), class AuthorModelView(viewsets.ModelViewSet):
queryset = Author.objects.all()
serializer_class = AuthorModelSerializers
url 配置
from rest_framework import routers
routers = routers.DefaultRouter()
routers.register('authors',views.AuthorView) urlpatterns = [
...
re_path('^',include(routers.urls)),
...
]

3 分页器

django有分页

rest 也有分页

1.简单分页

(1)源码

page_size   每页显示多少条数据
page_query_param 分页结果集中的页码
page_size_query_param 每页返回的结果数
max_page_size
将其设置为整数,以限制客户机可能请求的最大页面大小
Only relevant if 'page_size_query_param' has also been set

(2)全局配置

test

(3)局部配置

每页显示2个
参数 page
page=1 &size = 3
第一页默认2条,临时改成3条
最大不能超过3个,限制临时size

先分页,分完后,进行序列化

2.偏移分页(不常用)

(1) 源码

default_limit 
limit_query_param  每页返回的结果数。
offset_query_param 返回结果的初始索引

(2)自定义

默认显示1

(3)test

在此基础后,偏移1

拿到第二个,类似于 相对路径

3.视图3 Viewset:一句话分页

(1)对于视图modelviewset,如何分页?

只需要加1个即可,源码里面有分页

谁的self.paginate_queryset(queryset)

找pagination_class即可

(2)以后,3句话就完成分页了

(3)test

4.代码

views

from rest_framework.pagination import PageNumberPagination  # 简单分页
from rest_framework.pagination import LimitOffsetPagination # 偏移分页 class MyPageNumberPagination(PageNumberPagination):
page_size = 1
page_query_param = 'page'
page_size_query_param = 'size'
max_page_size = 3 class MyLimitOffsetPagination(LimitOffsetPagination):
default_limit = 1 class BookView(APIView): def get(self,request):
book_list = Book.objects.all() # 分页
pnp = MyPageNumberPagination()
# pnp = LimitOffsetPagination()
book_age = pnp.paginate_queryset(book_list,request,self) bs = BookModelSerializers(book_age,many=True,context={'request':request})
return Response(bs.data) # Response继承HttpResponse def post(self,request):
# post请求的数据
print(request.data)
# self.dispatch
bs = BookModelSerializers(data=request.data,context={'request':request})
if bs.is_valid():
print(bs.validated_data)
bs.save() # create方法
return Response(bs.data)
else:
return Response(bs.errors) # Author
# 视图三部曲,最后一种
from rest_framework import viewsets class AuthorView(viewsets.ModelViewSet):
queryset = Author.objects.all()
serializer_class = AuthorModelSerializers
pagination_class = MyPageNumberPagination

settings

REST_FRAMEWORK = {
# Pagination
'PAGE_SIZE': 1,
}

4 Response响应器

1.之前提到的

https://www.cnblogs.com/venicid/p/11231983.html#_label3_1

2、源码

Response  只是一堆数据

HTTPResponse 只能放字符串

用浏览器的话,默认是用户,给个html页面

方便用户操作

后续可以delete请求,只有json数据的话,没有

实质还是请求的还是数据

实质:json数据

5 渲染器

1.demo

主urls

from django.contrib import admin
from django.urls import path,re_path,include urlpatterns = [
path('admin/', admin.site.urls),
path('api/',include('api.urls'))
]

api.urls

from django.urls import path,re_path,include

from api.views import course
urlpatterns = [
re_path('^course',course.CourseViews.as_view())
]

view

from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework.renderers import JSONRenderer,BrowsableAPIRenderer from django.shortcuts import HttpResponse class CourseViews(APIView): # renderer_classes = [JSONRenderer,BrowsableAPIRenderer]
renderer_classes = [JSONRenderer] def get(self,request,*args,**kwargs):
self.dispatch # 快速找dispatch
return Response('course...') # 出错了,没有在app中注册 rest_framework
# return HttpResponse('course...')

settings

INSTALLED_APPS = [
...
'rest_framework',
] ...
REST_FRAMEWORK = {
'DEFAULT_RENDERER_CLASSES': ['rest_framework.renderers.JSONRenderer',
'rest_framework.renderers.BrowsableAPIRenderer'],
}

2.rest_framework如何渲染的

3. 渲染器 JSONRenderer和BrowsableAPIRenderer

一般情况用json即可

restframe实质:把你的json数据嵌套到html中显示

4.全局配置

源码

我的settings设置

6 版本 /api/v1/

1.源码剖析

5种支持的版本传参

继承BaseVersioning

5个类,2个不用

参数配置

2.方法1(不推荐)

(1)源码

实质:django中request的get方法

version参数,与默认

只能指定 v1 v2

(2)局部配置

urls

(3)全局配置

(4)test

不同verison 能拿到不同的版本

 

没有允许的版本

默认的

3.方法2 URLPathVersioning (推荐版本)

(1)局部配置

version会传到kwargs

(2)全局配置过(推荐版本)

url

(3)test

4. Code和笔记

1、笔记

    2. 版本
原理:要了解
使用:
1. 添加配置
REST_FRAMEWORK = {
....
'DEFAULT_VERSIONING_CLASS':'rest_framework.versioning.URLPathVersioning',
'ALLOWED_VERSIONS':['v1','v2'], # 允许的版本
'VERSION_PARAM':'version', # 参数
'DEFAULT_VERSION':'v1', # 默认版本
....
} 2. 设置路由 s9luffycity/urls.py
urlpatterns = [
#url(r'^admin/', admin.site.urls),
url(r'^api/(?P<version>\w+)/', include('api.urls')),
] api/urls.py
urlpatterns = [
url(r'^course/$', course.CourseView.as_view()),
] 3. 获取版本
request.version 获取版本

2、代码

主url

from django.contrib import admin
from django.urls import path,re_path,include urlpatterns = [
path('admin/', admin.site.urls), # re_path('api/(?P<version>[v1|v2]+)/',include('api.urls')),
re_path('api/(?P<version>\w+)/',include('api.urls'))
]

api.url

from django.urls import path,re_path,include

from api.views import course
urlpatterns = [
re_path('^course',course.CourseViews.as_view())
]

api.views.course

from django.shortcuts import HttpResponse

from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework.renderers import JSONRenderer,BrowsableAPIRenderer from rest_framework.versioning import QueryParameterVersioning
from rest_framework.versioning import URLPathVersioning class CourseViews(APIView): # versioning_class = QueryParameterVersioning
# versioning_class = URLPathVersioning # 推荐版本 # renderer_classes = [JSONRenderer] # 一般情况使用json即可
# renderer_classes = [JSONRenderer,BrowsableAPIRenderer]
def get(self,request,*args,**kwargs): # version会传到kwargs
# self.dispatch # 快速找dispatch
print(request.version)
return Response('course...') # 出错了,没有在app中注册 rest_framework
# return HttpResponse('course...')

settings

REST_FRAMEWORK = {
'DEFAULT_RENDERER_CLASSES': ['rest_framework.renderers.JSONRenderer',
'rest_framework.renderers.BrowsableAPIRenderer'],
# Versioning
'DEFAULT_VERSION': 'v1', # 默认的版本
'ALLOWED_VERSIONS': ['v1','v2'], # 允许的版本
'VERSION_PARAM': 'version', # 参数 # 方式1
# from rest_framework.versioning import QueryParameterVersioning
'DEFAULT_VERSIONING_CLASS':'rest_framework.versioning.QueryParameterVersioning', # 方式2:推荐
# from rest_framework.versioning import URLPathVersioning
# 'DEFAULT_VERSIONING_CLASS':'rest_framework.versioning.URLPathVersioning',
}

5 解析器、url路由控制、分页、渲染器和版本的更多相关文章

  1. Django_rest_framework_渲染器/解析器/路由控制/分页

    目录 渲染器 解析器 路由控制 分页 渲染器 简介 什么是渲染器 根据 用户请求URL 或 用户可接受的类型,筛选出合适的 渲染组件. 渲染器的作用 序列化.友好的展示数据 渲染器配置 首先要在set ...

  2. Django 02 url路由配置及渲染方式

    Django 02 url路由配置及渲染方式 一.URL #URL #(Uniform Resoure Locator) 统一资源定位符:对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示,是 ...

  3. restful(3):认证、权限、频率 & 解析器、路由控制、分页、渲染器、版本

    models.py中: class UserInfo(models.Model): name = models.CharField(max_length=32) psw = models.CharFi ...

  4. rest_framework之解析器、路由控制、分页

    解析器 我们都知道,网络传输数据只能传输字符串格式的,如果是列表.字典等数据类型,需要转换之后才能使用 但是我们之前的rest_framework例子都没有转换就直接可以使用了,这是因为rest_fr ...

  5. drf 解析器,响应器,路由控制

    解析器 作用: 根据请求头 content-type 选择对应的解析器对请求体内容进行处理. 有application/json,x-www-form-urlencoded,form-data等格式 ...

  6. Django REST Framework - 分页 - 渲染器 - 解析器

    为什么要使用分页? 我们数据表中可能会有成千上万条数据,当我们访问某张表的所有数据时,我们不太可能需要一次把所有的数据都展示出来,因为数据量很大,对服务端的内存压力比较大还有就是网络传输过程中耗时也会 ...

  7. Restful framework【第十一篇】url路由控制

    基本使用 -url控制 -传统的url配置 url(r'^books/$', views.BookView.as_view()), url(r'^books/(?P<pk>\d+)$', ...

  8. Django 学习第二天——URL路由及模板渲染方式

    URL 的概念及格式: URL的引入:客户端:知道了url 就可以去进行访问: 服务端:设置好了url,别人才能访问到我 URL :网址(全球统一资源定位符):由 协议,域名(ip port) ,路径 ...

  9. django中url路由配置及渲染方式

    今天我们学习如何配置url.如何传参.如何命名.以及渲染的方式,内容大致有以下几个方面. 创建视图函数并访问 创建app django中url规则 捕获参数 路径转换器 正则表达式 额外参数 渲染方式 ...

随机推荐

  1. springboot2.0application.在yml文件中添加自定义配置

    1. 在application.yml文件中添加自定义配置 app: platform: version: code: '1.0.0' 2. 定义bean类   具体格式: 其中的成员变量名称需要与配 ...

  2. X86逆向14:常见的脱壳手法

    本章节内容将介绍软件的脱壳技术.什么是加壳?加壳就是用来压缩或者保护软件不被非法修改破解的一种工具,而脱壳就是将已经加壳的程序从壳中剥离出来,既然能给程序进行加壳,那也就会有相应的脱壳方法,本节课我们 ...

  3. X86逆向8:向程序中插入新区段

    本节课我们不去破解程序,本节课学习给应用程序插入一些代码片段,这里我就插入一个弹窗喽,当然你也可以插入一段恶意代码,让使用的人中招, 这里有很多原理性的东西我就不多罗嗦了毕竟是新手入门教程,如果想去了 ...

  4. 27-Perl 进程管理

    1.Perl 进程管理Perl 中你可以以不同的方法来创建进程.本教程将讨论一些进程的管理方法. 你可以使用特殊变量 $$ 或 $PROCESS_ID 来获取进程 ID. %ENV 哈希存放了父进程, ...

  5. 进阶Java编程(10)反射与简单Java类

    1,传统属性自动赋值弊端 简单Java类主要由属性构成,并且提供有setter与getter类,同时简单Java类最大的特征就是通过对象保存相应的类属性的内容.但是如果使用传统的简单Java类开发,那 ...

  6. 【原创】Java基础之Nginx缓存

    1 proxy_ignore_headers 1.1 Set-Cookie By default, nginx does not caches requests with Set-Cookie. 默认 ...

  7. MFC 下调试 出现 warning : fail to load indicator string 0x0069

    MFC 下调试 出现 warning : fail to load indicator string 0x0069 就是程序状态栏每一个标识列中至少有一个值没有初始值 或初始值为空 导致程序没有获取到 ...

  8. LeetCode:620.有趣的电影

    题目链接:https://leetcode-cn.com/problems/not-boring-movies/ 题目 某城市开了一家新的电影院,吸引了很多人过来看电影.该电影院特别注意用户体验,专门 ...

  9. LeetCode 172:阶乘后的零

    给定一个整数 n, 返回 n! 结果中尾数为零的数量. 示例 : 输入: 输出: 解释: ! = , 尾数中没有零. 示例 : 输入: 输出: 解释: ! = , 尾数中有个零. 说明:算法的时间复杂 ...

  10. VS2019 快捷键

    工欲善其事,必先利其器,整理了下VS最常用的快捷键,查看了不少资料,汇总了下,没有的自己补充,可以打印,用Excel编辑的. 可编辑版本下载:Excel文件下载 你可能需要查询其他的快捷键,MSDN介 ...