美文网首页软件测试
9、Django视图(View与APIView)

9、Django视图(View与APIView)

作者: 小啊小狼 | 来源:发表于2020-09-21 11:44 被阅读0次

前言

django中编辑视图views.py有两种方式,一种是基于类的实现,另外一种是函数式的实现方式,两种方法都可以用。
REST框架提供了一个APIView类,它是Django View类的子类。

一、View与APIView的区别

View是Django默认的视图基类,APIView是REST framework提供的所有视图的基类, 继承自Django的View,对Django中的View进行了拓展,具备了认证、授权、限流、不同请求数据的解析的功能。

1.传入到视图方法中的是REST framework的Request对象,而不是Django的HttpRequeset对象;

a.统一使用Request对象.data属性去获取json格式的参数、form表单参数、FILES
b、使用Request对象.query_params来获取查询字符串参数
c、Django支持的参数获取方式,DRF都支持

  • .GET --> 查询字符串参数 --> .query_params
  • .POST --> x-www-form-encoded
  • .body --> 获取请求体参数

2.视图方法可以返回REST framework的Response对象,视图会为响应数据设置(render)符合前端要求的格式;

a.对Django中的HttpResponse进行了拓展
b.实现了根据请求头中Accept参数来动态返回
c.默认情况下,如果不传Accept参数或者传参为application/json,那么会返回json格式的数据

  • 1.可以在全局配置settings中修改默认的渲染类(处理返回的数据形式)
  • 2.列表中的元素是有优先级的,第一个元素优先级最高
REST_FRAMEWORK = {
    'NON_FIELD_ERRORS_KEY': 'errors',
    # a.可以修改默认的渲染类(处理返回的数据形式)
    'DEFAULT_RENDERER_CLASSES': [
        # b.列表中的元素是有优先级的,第一个元素优先级最高
        'rest_framework.renderers.JSONRenderer',
        'rest_framework.renderers.BrowsableAPIRenderer',
    ],

d.如果Accept参数为text/html,那么会返回可浏览的api页面(html页面)
e.Response第一个参数为,经过序列化之后的数据(往往需要使用序列化器对象.data)
f.status指定响应状态码

3.在进行dispatch()分发前,会对请求进行身份认证、权限检查、流量控制。

authentication_classes 身份认证
permission_classes 权限检查
throttle_classes 流量控制

二、实现

django的View

先使用django自带的view,获取一个Card表里面的卡号信息:
models.py设计card表

# models.py
class Card(models.Model):
    card_id = models.CharField(max_length=30, verbose_name="卡号", default="")
    card_user = models.CharField(max_length=10, verbose_name="姓名", default="")
    add_time = models.DateField(auto_now=True, verbose_name="添加时间")

    class Meta:
        verbose_name_plural = '银行卡账户'
        verbose_name = "银行卡账户_基本信息"
        
    def __str__(self):
        return self.card_id

views.py视图的编写

from django.http import JsonResponse
from rest_framework import serializers
from django.core import serializers as dj_serializers  # 避免和rest_framework里面的serializers冲突
from .models import *
from django.views.generic.base import View
import json


class CardListView(View):
    '''基于django的view实现获取card列表'''
    def get(self, request):
        data = {}
        cards = Card.objects.all()
        data['result'] = json.loads(dj_serializers.serialize("json", cards))
        return JsonResponse(data)

urls.py设置访问地址

from apiapp import views
from django.conf.urls import url

urlpatterns = [
    url(r'^api/v1/cards/$', views.CardListView.as_view()),
]

REST framework的APIView

REST framework的APIView继承了django的View类,先序列化Card类,这里的序列化用rest_framework里面的ModelSerializer

from rest_framework.response import Response
from rest_framework.views import APIView
from rest_framework import serializers
from .models import *
from rest_framework.permissions import IsAuthenticated,AllowAny
from rest_framework.authentication import TokenAuthentication

class CardAPISerializer(serializers.ModelSerializer):   # 继承自ModelSerializer类
    '''序列化数据的类,根据model表来获取字段'''
    class Meta:
        model = Card
        fields = '__all__'

class CardListAPIView(APIView):
    '''REST framework的APIView实现获取card列表 '''
    # authentication_classes = (TokenAuthentication,)  # token认证
    # permission_classes = (IsAuthenticated,)   # IsAuthenticated 仅通过认证的用户
    permission_classes = (AllowAny,)  # 允许所有用户

    def get(self, request, format=None):
        """
        Return a list of all users.
        """
        cards = Card.objects.all()
        serializer = CardAPISerializer(cards, many=True)
        return Response(serializer.data)

配置urls.py,设置访问地址

from apiapp import views
from django.conf.urls import url

urlpatterns = [
    url(r'^api/v1/cardlist/$', views.CardListAPIView.as_view()),
]

相关文章

网友评论

    本文标题:9、Django视图(View与APIView)

    本文链接:https://www.haomeiwen.com/subject/rccvyktx.html