Django REST framework 第二章 Request and Response
此章节开始真正的撰写REST framework的核心代码,介绍一系列必要的建立设计
Request Objects
REST framework介绍了一个Request对象用来扩展常规的HttpRequest,提供了更多灵活的请求解析。Request对象的核心功能是request.data属性跟request.POST非常相似,但是在WEB APIs方面更能发挥作用。
request.POST # 只处理表单数据,只能用于POST方法
request.data # 处理任意的数据,作用于POST、PUT、PATCH方法
Response Objects
REST framework还引入了一个响应对象Response,它是一种TemplateResponse类型,采用没有render内容和使用内容协商来确定正确的内容类型并返回给客户端.
return Response(data) # 转换到客户端需要的内容类型Renders to content type as requested by the client.
Status codes
使用数字HTTP状态码在你的视图内不会总是被明显的阅读到,并且很容易不被注意到,如果你拿到了一个错误的错误代码。REST framework提供了更多明确的标识符为每一个状态码,比如HTTP_400_BAD_REQUEST在状态模块单元里。相比于使用数字标识符,广泛使用这些是一个更好的主意。
Wrapping API views
REST framework提供了2种你可以使用来写API 视图的包装:
1、@api_view装饰器为FBV服务
2、APIView类为CBV服务
这些封装提供了一些功能,比如确定你能接受到Request实例在视图中,添加上下文到Response对象从而可以进行内容协商转换。此外还提供了一些行为,比如返回405 Method Not Allowed返回值在合适的时候,当访问的request.data是很畸形的输入时处理任何ParseError错误
Pulling it all together
好了,现在开始使用这些新组件写一些视图。
views.py文件中再不需要JSONResponse类,所以继续并删除掉它。一旦完成,就可以开始稍微重构视图。
from app01.models import Snippet
from app01.serializers import SnippetSerializer
from rest_framework import status
from rest_framework.decorators import api_view
from rest_framework.response import Response @api_view(['GET', 'POST'])
def snippet_list(request):
"""
List all code snippets, or create a new snippet.
"""
if request.method == 'GET':
snippets = Snippet.objects.all()
serializer = SnippetSerializer(snippets, many=True) # queryset对象,配合many=True
return Response(serializer.data) elif request.method == 'POST':
serializer = SnippetSerializer(data=request.data) # 没有跟之前的一样先反序列化,后用字典形式作为参数传入,而是直接用request.data传入
if serializer.is_valid():
serializer.save()
return Response(serializer.data, status=status.HTTP_201_CREATED)
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
我们的实例视图是前面的示例的一次改进。这是一个更简洁方案,并且感觉代码非常相似,如果我们正在使用表单API。我们也在使用被命名的状态码,这会让返回的含义更加明显。
@api_view(['GET', 'PUT', 'DELETE'])
def snippet_detail(request, pk):
"""
获取、更新、删除
"""
try:
snippet = Snippet.objects.get(pk=pk) # model类单个对象实例
except Snippet.DoesNotExist:
return Response(status=status.HTTP_404_NOT_FOUND) # 未获取到信息 if request.method == 'GET':
serializer = SnippetSerializer(snippet)
return Response(serializer.data) # response内部解决了序列化问题 不需要再写JsonResponse(serializer.data, safe=False) elif request.method == 'PUT':
serializer = SnippetSerializer(snippet, data=request.data) # 跟form里面的更新操作也很类似
if serializer.is_valid():
serializer.save()
return Response(serializer.data) # 单个对象的data是一个字典,多个对象的是list,需要safe=False
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST) elif request.method == 'DELETE':
snippet.delete()
return Response(status=status.HTTP_204_NO_CONTENT) # 成功 没有数据
这应该会让你感觉很熟悉,跟普通Django内部的视图没有太大差异。
注意,我们不再明确给request或者response打上一个明确的内容类型. request.data可以处理即将到来的json请求,但它也可以处理其他格式的. 相似地也会返回带有数据的respose对象,但是允许REST framework为我们去转换response到正确的类型。
Adding optional format suffixes to our URLs
为了充分利用,事实上返回不在与单个内容类型硬连线,让我们添加对API端点的格式后缀的支持。使用格式后缀能显式地引用给定格式的URLs,意味着API将会能够处理URLs,比如http://example.com/api/items/4.json
在之前的两个视图内都加上关键字参数format
def snippet_list(request, format=None):
.... def snippet_detail(request, pk, format=None):
....
更新app内的url文件
from app01 import views
from django.urls import path, include
from rest_framework.urlpatterns import format_suffix_patterns app_name = 'app01'
urlpatterns = [
path('snippets/', views.snippet_list),
path('snippets/<int:pk>/', views.snippet_detail),
]
urlpatterns = format_suffix_patterns(urlpatterns)
我们不一定要加上这些额外的URL模式,但它为我们提供了一个简单的,指特定格式的清洁方式。
如果按照之前的章节一步步做到这个遇到下面这个问题,请到setting里面把REST_FRAMEWORK注释掉,因为将之前的视图注释掉了,没有用到Django内置的auth,具体说不清,但是确实是那边功能缺失。
注释掉此段:
# REST_FRAMEWORK = {
# # Use Django's standard `django.contrib.auth` permissions,
# # or allow read-only access for unauthenticated users.
# 'DEFAULT_PERMISSION_CLASSES': [
# 'rest_framework.permissions.DjangoModelPermissionsOrAnonReadOnly'
# ]
# }
测试成效
测试一下下面的后缀
http http://127.0.0.1:8000/app01/snippets/ Accept:application/json # Request JSON
http http://127.0.0.1:8000/app01/snippets/ Accept:text/html # Request HTML
http http://127.0.0.1:8000/app01/snippets.json # JSON suffix
http http://127.0.0.1:8000/app01/snippets.api # Browsable API suffix
相似的,我们可以控制发送的请求的格式,使用Content-Type 头。
http --json POST http://127.0.0.1:8000/app01/snippets/ "code=11"
如果添加--debug在上面的额http请求,你讲可以看到请求类型在请求头里面。同样的也可以在web浏览器里访问
Django REST framework 第二章 Request and Response的更多相关文章
- DRF (Django REST framework) 中的Request 与 Response
DRF中的Request 与 Response 1. Request - REST framework 传入视图的request对象不再是Django默认的HttpRequest对象,而是REST f ...
- 徒手用Java来写个Web服务器和框架吧<第二章:Request和Response>
徒手用Java来写个Web服务器和框架吧<第一章:NIO篇> 接上一篇,说到接受了请求,接下来就是解析请求构建Request对象,以及创建Response对象返回. 多有纰漏还请指出.省略 ...
- Django REST framework 第一章 Serialization
此章节将会介绍多种构成REST framework的重要模块,在每个部分如何一起配合上提供一个综合的全方面的了解. 准备 同样的创建一个新项目,创建一个新的app,将rest_framework跟新建 ...
- (转)Django学习之 第二章:Django快速上手
安装Python 安装Django非常容易.因为Django可以运行在任何可以运行Python的环境中,所以可以以多种方式进行配置. 在本章我们将尝试覆盖几种常见的Django安装场景. Djang ...
- Django Rest framework 框架之认证使用和源码执行流程
用这个框架需要先安装: pip3 install djangorestframework 如果写了一个CBV的东西,继承了View. # 继承Django里面View class APIView(Vi ...
- django restframwork教程之Request和Response
从这一篇文章开始,我们会覆盖整个REST framwork框架的核心,接下来让我们介绍一些基础的构建块 Request 对象 REST framework 引入了一个扩展HttpRequest的请求对 ...
- Django restful Framework 之Requests and Response 方法
前言: 本章主要介绍REST framework 内置的必要的功能. Request objects Response objects Status codes Wrapping API views ...
- 《Django By Example》第二章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:翻译完第一章后,发现翻译第二章的速 ...
- 第二章、Django以及数据库的配置
目录 第二章.Django以及数据库的配置 一.小白必会三板斧 二.静态文件配置 三.form表单 action和method参数可以写的形式 四.request对象及方法 五.django连接数据库 ...
随机推荐
- 第三十节,目标检测算法之Fast R-CNN算法详解
Girshick, Ross. “Fast r-cnn.” Proceedings of the IEEE International Conference on Computer Vision. 2 ...
- java方法笔记: split,instanceof,StringBuilder(),append(),string ,Integer,Math,正则表达式
http://swiftlet.net/archives/709 如果分隔符在前方,会显示“”,在尾部不显示: *|做分割,需要加\\ API文档如下 1.instanceof 查看前者是否是后者的实 ...
- (贪心)P1223 排队接水 洛谷
题目描述 有n个人在一个水龙头前排队接水,假如每个人接水的时间为Ti,请编程找出这n个人排队的一种顺序,使得n个人的平均等待时间最小. 输入输出格式 输入格式: 输入文件共两行,第一行为n:第二行分别 ...
- mysql删除大表更快的drop table办法
mysql删除大表更快的drop table办法 参考资料:https://blog.csdn.net/anzhen0429/article/details/76284320 利用硬链接和trunca ...
- bzoj1003 最短路+dp
遇到小范围数据的题目就容易被限制了思维,我单知道数据小可以跑很多遍最短路,但我没想到暴力跑N ^ 2的最短路也能过 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输 ...
- Java引用类型传递整理
引用数据类型(类) 10.1引用数据类型分类 可以把类的类型为两种: Java为我们提供好的类,如Scanner类,Random类等,这些已存在的类中包含了很多的方法与属性,可供我们使用. 我们自己创 ...
- 记录一次php连接mssql的配置
记录一次php连接mssql的配置 在现有php环境中,php连接mssql数据库失败,tsql 连接正常. 确认问题在php环境上. 网上有个同仁总结的很好,https://blog.csdn.ne ...
- 从Paxos到Zookeeper分布式一致性原理与实践 读书笔记之(一) 分布式架构
1.1 从集中式到分布式 1 集中式特点 结构简单,无需考虑对多个节点的部署和节点之间的协作. 2 分布式特点 分不性:在时间可空间上随意分布,机器的分布情况随时变动 对等性:计算机之间没有主从之分 ...
- Android开发入门经典实例
开发实例概述 今天带大家做一个简单的Android App,这个App会显示创新工程实践老师们的照片和信息,不妨先看一看效果: 虽然这个App非常简单,但是涉及到了Android开发中的一些关键知识, ...
- Storm基本原理概念及基本使用
1. 背景介绍 1.1 离线计算是什么 离线计算:批量获取数据.批量传输数据.周期性批量计算数据.数据展示: 代表技术:Sqoop批量导入数据.HDFS批量存储数据.MapReduce批量计算数据.H ...