前言
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()),
]
网友评论