rest framework 之渲染器

根据 用户请求URL 或 用户可接受的类型,筛选出合适的 渲染组件。

用户请求头:

Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8

一、JSON

1、urls.py

from django.urls import path, re_path, include
from api.views import TestView2

urlpatterns = [
    re_path(r'(?P<version>[v1|v2]+)/test2', TestView2.as_view()),
]

2、views.py

from rest_framework.response import Response
from rest_framework.renderers import JSONRenderer
from rest_framework import serializers

class Test2Serializers(serializers.ModelSerializer):
    class Meta:
        model = models.Role
        fields = '__all__'

class TestView2(APIView):
    renderer_classes = [JSONRenderer]

    def get(self, request, *args, **kwargs):
        roles = models.Role.objects.all()
        roles_ser = Test2Serializers(instance=roles, many=True)

        return Response(roles_ser.data)

3、访问 URL:

http://127.0.0.1:8000/api/v1/test2/?format=json
http://127.0.0.1:8000/api/v1/test2/.json
http://127.0.0.1:8000/api/v1/test2

二、表格

1、views.py

from rest_framework.response import Response
from rest_framework.renderers import AdminRenderer
from rest_framework import serializers

class Test2Serializers(serializers.ModelSerializer):
    class Meta:
        model = models.Role
        fields = '__all__'

class TestView2(APIView):
    renderer_classes = [AdminRenderer]

    def get(self, request, *args, **kwargs):
        roles = models.Role.objects.all()
        roles_ser = Test2Serializers(instance=roles, many=True)

        return Response(roles_ser.data)

2、访问 URL:

http://127.0.0.1:8000/api/v1/test2/?format=admin
http://127.0.0.1:8000/api/v1/test2/.admin
http://127.0.0.1:8000/api/v1/test2

三、Form 表单

1、views.py

from rest_framework.response import Response
from rest_framework.renderers import HTMLFormRenderer
from rest_framework import serializers

class Test2Serializers(serializers.ModelSerializer):
    class Meta:
        model = models.Role
        fields = '__all__'

class TestView2(APIView):
    renderer_classes = [HTMLFormRenderer]

    def get(self, request, *args, **kwargs):
        roles = models.Role.objects.all().first()       # 一个,不是全部
        roles_ser = Test2Serializers(instance=roles, many=False)

        return Response(roles_ser.data)

2、访问 URL:

http://127.0.0.1:8000/api/v1/test2/?format=html
http://127.0.0.1:8000/api/v1/test2/.html
http://127.0.0.1:8000/api/v1/test2

四、自定义显示模板

1、views.py

from rest_framework.response import Response
from rest_framework.renderers import TemplateHTMLRenderer
from rest_framework import serializers

class Test2Serializers(serializers.ModelSerializer):
    class Meta:
        model = models.Role
        fields = '__all__'

class TestView2(APIView):
    renderer_classes = [TemplateHTMLRenderer]

    def get(self, request, *args, **kwargs):
        roles = models.Role.objects.all().first()       # 一个,不是全部
        roles_ser = Test2Serializers(instance=roles, many=False)

        return Response(roles_ser.data, template_name='roles_detail.html')

2、访问 URL:

http://127.0.0.1:8000/api/v1/test2/?format=html
http://127.0.0.1:8000/api/v1/test2/.html
http://127.0.0.1:8000/api/v1/test2

3、templates/roles_detail.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    {{ 123 }}
</body>
</html>

五、浏览器格式 API+JSON

1、views.py

from rest_framework.response import Response
from rest_framework.renderers import BrowsableAPIRenderer, JSONRenderer
from rest_framework import serializers

class Test2Serializers(serializers.ModelSerializer):
    class Meta:
        model = models.Role
        fields = '__all__'

class CustomBrowsableAPIRenderer(BrowsableAPIRenderer):
    def get_default_renderer(self, view):
        return JSONRenderer()

class TestView2(APIView):
    renderer_classes = [CustomBrowsableAPIRenderer]

    def get(self, request, *args, **kwargs):
        roles = models.Role.objects.all()
        roles_ser = Test2Serializers(instance=roles, many=True)

        return Response(roles_ser.data)

2、访问 URL:

http://127.0.0.1:8000/api/v1/test2/?format=api
http://127.0.0.1:8000/api/v1/test2/.api
http://127.0.0.1:8000/api/v1/test2

Tips:如果同时多个存在时,自动根据URL后缀来选择渲染器。

六、全局配置

REST_FRAMEWORK = {
    "DEFAULT_RENDERER_CLASSER": [
        'rest_framework.renderers.JSONRenderer',
        'rest_framework.renderers.BrowsableAPIRenderer',
    ]
}

参考文章:Django Rest Framework

原文地址:https://www.cnblogs.com/midworld/p/11380195.html

时间: 2024-08-29 19:46:03

rest framework 之渲染器的相关文章

Django Restful Framework【第五篇】分页、视图、路由、渲染器

一.分页 试问如果当数据量特别大的时候,你是怎么解决分页的? 方式a.记录当前访问页数的数据id 方式b.最多显示120页等 方式c.只显示上一页,下一页,不让选择页码,对页码进行加密 1.基于limit offset 做分页 from rest_framework.pagination import LimitOffsetPagination urls.py urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^app01/(?P<v

9.6 rest framework 解析器,渲染器

解析器 解析器的作用 解析器的作用就是服务端接收客户端传过来的数据,把数据解析成自己可以处理的数据.本质就是对请求体中的数据进行解析. 请求体相关字段: Accept:指定了接收的数据类型 ContentType:指定了传递的数据类型 解析器工作原理的就是拿到请求的ContentType来判断前端给我的数据类型是什么,然后我们在后端使用相应的解析器去解析数据. ps: django 原生是不支持 json 类型的数据,数据通过request.get 是拿不到的,只能在 request.body

Django REST Framework 解析器与渲染器

01-解析器 REST 框架包括一些内置的Parser类,允许你接受各种媒体类型的请求.还支持定义自己的自定义解析器,这使你可以灵活地设计API接受的媒体类型. 注意: 开发客户端应用程序时应该始终记住在HTTP请求中发送数据时确保设置Content-Type头. 如果你不设置内容类型,大多数客户端将默认使用'application/x-www-form-urlencoded',而这可能并不是你想要的. 举个例子,如果你使用jQuery的.ajax() 方法发送json编码数据,你应该确保包含c

DRF 版本、认证、权限、限制、解析器和渲染器

目录 一.DRF之版本控制 为什么要有版本控制? DRF提供的版本控制方案 版本的使用 全局配置 局部配置(使用较少) 二.DRF之认证 内置的认证 步骤 三.DRF之权限 1.自定义一个权限类 2.权限 局部配置 3.权限 全局配置 四.DRF之限制 1.使用自定义限制类 1.1自定义一个限制类 1.2限制 局部配置 1.3限制 全局配置 2.使用内置限制类 2.1定义内置限制类 2.2全局配置 五.DRF之分页 1.为什么要使用分页 2.DRF使用分页器 2.1分页模式 2.2全局配置 2.

基于OpenGL编写一个简易的2D渲染框架-08 重构渲染器-整体架构

事实上,前面编写的渲染器 Renderer 非常简陋,虽然能够进行一些简单的渲染,但是它并不能满足我们的要求. 当渲染粒子系统时,需要开启混合模式,但渲染其他顶点时却不需要开启混合模式.所以同时渲染粒子系统和其他纹理时会得不到想要的结果,渲染器还存在许多的不足: 1.当渲染许多透明图形时,没有对其进行排序,使得本应透明的图形没有透明. 2.不能对不同的顶点使用不同的状态进行渲染. 渲染器要做的东西很简单,就是 1.传递数据到 GPU 2.设置 OpenGL 状态信息(Alpha测试.模板测试.深

上下文渲染器RequestContext

在render_to_response中加RequestContext会将settings中设置的context_processors返回值收集起来传到模板 return render_to_response('index.html', {...}, context_instance=RequestContext(request)) settings.py TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemp

通过渲染器Shader实现图像变换效果

在上一篇文章中,一起学习了通过设定画笔风格来实现图形变换,没读过的朋友可以点击下面链接: http://www.cnblogs.com/fuly550871915/p/4886455.html 是不是觉得自己学到的知识更多了呢?那么再多学一点总没坏处.在本篇文章中,将会一起学习通过给画笔设定Shader属性,实现图形变换.并带领读者一起实现两个实际例子,图片渲染器和线性渲染器.有没有发现我们的画笔特别强大呢??确实,我们曾经给它设置过颜色矩阵属性,设置过xfermode风格属性,现在又来设定Sh

基于OpenGL编写一个简易的2D渲染框架-11 重构渲染器-Renderer

假如要渲染一个纯色矩形在窗口上,应该怎么做? 先确定顶点的格式,一个顶点应该包含位置信息 vec3 以及颜色信息 vec4,所以顶点的结构体定义可以这样: struct Vertex { Vec3 position; Vec4 color; }; 然后填充矩形四个顶点是数据信息: Vertex* data = ( Vertex* ) malloc(sizeof( Vertex ) * 4); data[0].position.set(0, 0, 0); data[1].position.set(

ZendFramework-2.4 源代码 - 关于MVC - View层 - 视图渲染器、视图插件管理器

<?php // 1. 视图渲染器 class PhpRenderer implements Renderer, TreeRendererInterface { /** * 插件管理器 */ public function getHelperPluginManager() { if (null === $this->__helpers) {// false $this->setHelperPluginManager(new HelperPluginManager()); } return