DRF框架中的演变View
import json from django.db import DatabaseError
from django.http import HttpResponse
from django.http import JsonResponse
from django.shortcuts import render
# Create your views here. from django.views import View # http://127.0.0.1:8000/books/ from rest_framework.authentication import SessionAuthentication
from rest_framework.decorators import action
from rest_framework.generics import GenericAPIView, CreateAPIView, ListAPIView, RetrieveAPIView, UpdateAPIView,DestroyAPIView, ListCreateAPIView, RetrieveUpdateDestroyAPIView
from rest_framework.mixins import ListModelMixin, CreateModelMixin, RetrieveModelMixin, UpdateModelMixin,DestroyModelMixin
from rest_framework.pagination import PageNumberPagination
from rest_framework.permissions import IsAuthenticated, AllowAny
from rest_framework.response import Response
from rest_framework.throttling import UserRateThrottle
from rest_framework.views import APIView
from rest_framework.viewsets import ModelViewSet from books.models import BookInfo, HeroInfo
from books.serializers import BookInfoSerializer, HeroInfoSerializer, BookInfoModelSerializer, HeroInfoModelSerializer,BookInfoSerializerForModidyRead
def test(request):
s = HeroInfoModelSerializer()
print(s)
return HttpResponse("OK") print("使用view开始")
# http://127.0.0.1:8000/heros/id/
class HeroView(View):
def get(self,request,pk):
try:
hero = HeroInfo.objects.get(pk=pk)
except Exception as e:
return HttpResponse(status=404)
serializer = HeroInfoSerializer(hero)
return JsonResponse(serializer.data) class BooksView(View):
def get(self, request):
try:
books = BookInfo.objects.all()
except Exception as e:
return HttpResponse(status=404)
serializer = BookInfoSerializer(books,many=True)
return JsonResponse(serializer.data,safe=False) def post(self, request):
json_bytes = request.body
json_str = json_bytes.decode()
json_dict = json.loads(json_str)
print(json_dict)
# 校验参数
serializer = BookInfoSerializer(data=json_dict)
# 如果校验不成功直接抛出异常
success = serializer.is_valid(raise_exception=True)
print(success)
if success:
serializer.save()
return JsonResponse(serializer.data,status=201) # http://127.0.0.1:8000/books/id/
class BookView(View): def get(self, request, pk):
try:
book = BookInfo.objects.get(pk=pk)
except Exception as e:
return HttpResponse(status=404)
serializer = BookInfoSerializer(book)
return JsonResponse(serializer.data) def put(self, request, pk):
try:
book = BookInfo.objects.get(pk=pk)
except Exception as e:
return HttpResponse(status=404)
json_bytes = request.body
json_str = json_bytes.decode()
json_dict = json.loads(json_str)
print(json_dict) serializer = BookInfoSerializer(instance=book, data=json_dict,partial=True)
# 如果校验不成功直接抛出异常
success = serializer.is_valid(raise_exception=True)
print(success)
if success:
serializer.save()
return JsonResponse(serializer.data,status=201) def delete(self, request, pk):
try:
book = BookInfo.objects.get(pk=pk)
except Exception as e:
return HttpResponse(status=404) book.delete()
return HttpResponse(status=204)
print("使用View结束")
print("使用APIView开始")
# 利用APIView中强大的request和response
# request中的request.data可以自动帮我们进行解码操作,因为其中含有DRF的Parser解析器,会自动的根据
# content-type解析数据,将解析的数据添加到Request类中,
# response可以根据我们的请求给我们返回我们需要的数据,用户想要什么界面就可以直接渲染出想要的结果
class BooksView(APIView):
def get(self, request):
books = BookInfo.objects.all()
serializer = BookInfoModelSerializer(books,many=True)
return Response(serializer.data) def post(self, request):
# 校验参数
serializer = BookInfoModelSerializer(data=request.data)
# 如果校验不成功直接抛出异常
success = serializer.is_valid(raise_exception=True)
if success:
serializer.save()
return Response(serializer.validated_data,status=201) # http://127.0.0.1:8000/books/id/
class BookView(APIView): def get(self, request, pk):
book = BookInfo.objects.get(pk=pk)
serializer = BookInfoModelSerializer(book)
return Response(serializer.data) def put(self, request, pk):
book = BookInfo.objects.get(pk=pk)
serializer = BookInfoModelSerializer(instance=book, data=request.data,partial=True)
# 如果校验不成功直接抛出异常
success = serializer.is_valid(raise_exception=True)
if success:
serializer.save()
return Response(serializer.validated_data,status=201) def delete(self, request, pk):
book = BookInfo.objects.get(pk=pk)
book.delete()
return HttpResponse(status=204)
print("使用APIView结束")
print("使用GenericAPIView开始")
class BooksView(GenericAPIView):
queryset = BookInfo.objects.all()
serializer_class = BookInfoModelSerializer def get(self, request):
books = self.get_queryset()
serializer = self.get_serializer(books,many=True)
return Response(serializer.data) def post(self, request):
# 校验参数
serializer = self.get_serializer(data=request.data)
# 如果校验不成功直接抛出异常
print(request.data)
success = serializer.is_valid(raise_exception=True)
print(success)
if success:
serializer.save()
return Response(serializer.validated_data,status=201) # http://127.0.0.1:8000/books/id/
class BookView(GenericAPIView):
queryset = BookInfo.objects.all()
# serializer_class = BookInfoModelSerializer
# lookup_url_kwarg 指定的是路径中参数的名称,默认叫pk
# lookup_field 指的是数据库中的字段
# lookup_field = "id" def get_serializer_class(self):
return BookInfoModelSerializer def get(self, request, pk):
book = self.get_object()
serializer = self.get_serializer(book)
return Response(serializer.data) def put(self, request, pk):
book = self.get_object()
serializer = self.get_serializer(instance=book, data=request.data,partial=True)
success = serializer.is_valid(raise_exception=True)
if success:
serializer.save()
return Response(serializer.validated_data,status=201) def delete(self, request, pk):
book = self.get_object()
book.delete()
return Response(status=204)
print("使用GenericAPIView以结束")
print("GenericAPIView的扩展类开始")
扩展类:针对于某一个类进行功能的扩展,只能够结合这个类进行使用,不能单独使用
子类:针对父类的功能进行扩展,可以单独使用
class BooksView(ListModelMixin,CreateModelMixin,GenericAPIView):
queryset = BookInfo.objects.all()
serializer_class = BookInfoModelSerializer def get(self, request):
return self.list(request) def post(self, request):
return self.create(request) class BookView(RetrieveModelMixin,UpdateModelMixin,DestroyModelMixin,GenericAPIView):
queryset = BookInfo.objects.all()
serializer_class = BookInfoModelSerializer def get(self, request, pk):
return self.retrieve(request,pk) def put(self, request, pk):
return self.update(request,pk) def delete(self, request, pk):
return self.destroy(request,pk)
print("GenericAPIView的扩展类以结束")
# ListAPIView --> get()
# CreateAPIView --> post()
# ListCreateAPIView
# get
# post
# RetrieveAPIView --> get()
# UpdateAPIView --> put() patch()
# DestroyAPIView --> delete()
# RetrieveUpdateAPIView --> get() put() patch()
# RetrieveDestroyAPIView --> get() delete()
# RetrieveUpdateDestroyAPIView --> get() put() patch() delete()
class BooksView(ListCreateAPIView):
queryset = BookInfo.objects.all()
serializer_class = BookInfoModelSerializer class BookView(RetrieveUpdateDestroyAPIView):
queryset = BookInfo.objects.all()
serializer_class = BookInfoModelSerializer
print("GenericAPIView的子类以结束")
print("使用视图集开始")
# 关于图书的这个资源,我们不想写两个类视图,我们就想写一个类
# 关于图书的操作:获取列表\增加\获取单个\修改\删除
# list()\create()\retrieve()\update()\destory()
# 视图集:视图集并不是必须的,如果你足够的懒,那么可以使用视图集
# 达到的效果:多个路径,只需要写一个class即可
# 注意:要在urls.py中来配置,不同路径\不同请求方法 究竟应该调用哪个方法
# 视图集的功能:可以让我们通过不同的路径,访问到同一个class中不同方法
# 视图集中自定义动作的实现:
# 1\在urls.py中配置好路径和这个class中哪个方法的映射关系
# 2\在这个class中通过def的方式定义好方法, 这个方法中得要有request参数,可能会有pk
# http://127.0.0.1:8000/books/?page=2&page_size=2/
class LargeResultsSetPagination(PageNumberPagination):
page_size = 2
page_size_query_param = 'page_size'
max_page_size = 10 class BookViewSet(ModelViewSet):
"""
list:
获取图书信息
retrieve:
获取 单个图书信息
latest:
获取图书的最新信息
read:
修改图书阅读量的数据 """
queryset = BookInfo.objects.all()
# throttle_classes = (UserRateThrottle,)
filter_fields = ('btitle', 'bread')
pagination_class = LargeResultsSetPagination def get_permissions(self):
if self.action == "latest":
return [IsAuthenticated()]
return [AllowAny()] # 我们可以通过视图集中的self.action决定当前是哪一种动作,通过不同的动作,返回不同的序列化器类的引用
def get_serializer_class(self):
if self.action == "read":
return BookInfoSerializerForModidyRead
return BookInfoModelSerializer @action(methods=["get"],detail=False)
def latest(self,request):
raise DatabaseError() book = BookInfo.objects.latest("id")
s = self.get_serializer(book)
return Response(s.data) @action(methods=["put"],detail=True)
def read(self,request,pk):
book = self.get_object()
s = self.get_serializer(book,data=request.data)
success = s.is_valid(raise_exception=True)
if success:
s.save()
return Response(s.validated_data,status=201)
print("使用视图集ViewSet结束")
# 局部限流
class BookDetailView(RetrieveAPIView):
queryset = BookInfo.objects.all()
serializer_class = BookInfoModelSerializer
authentication_classes = [SessionAuthentication]
permission_classes = [IsAuthenticated]
throttle_classes = (UserRateThrottle,)
# 局部过滤
class BookListView(ListAPIView):
queryset = BookInfo.objects.all()
serializer_class = BookInfoModelSerializer
filter_fields = ('btitle', 'bread')
DRF框架中的演变View的更多相关文章
- django drf框架中的user验证以及JWT拓展的介绍
登录注册是几乎所有网站都需要去做的接口,而说到登录,自然也就涉及到验证以及用户登录状态保存,最近用DRF在做的一个关于网上商城的项目中,引入了一个拓展DRF JWT,专门用于做验证和用户状态保存.这个 ...
- drf框架中所有视图及用法
0909自我总结 drf框架中所有视图及用法 一.drf框架中的所有视图类 from django.views import View from rest_framework import views ...
- drf框架中jwt认证,以及自定义jwt认证
0909自我总结 drf框架中jwt 一.模块的安装 官方:http://getblimp.github.io/django-rest-framework-jwt/ 他是个第三方的开源项目 安装:pi ...
- DRF框架中分页功能接口
目录 DRF框架中分页功能接口 DRF框架中分页功能接口 一.在框架中提供来三个类来实现分页功能,PageNumberPagination.LimitOffsetPagination.CursorPa ...
- drf框架中认证与权限工作原理及设置
0909自我总结 drf框架中认证与权限工作原理及设置 一.概述 1.认证 工作原理 返回None => 游客 返回user,auth => 登录用户 抛出异常 => 非法用户 前台 ...
- drf框架中分页组件
drf框架中分页组件 普通分页(最常用) 自定制分页类 pagination.py from rest_framework.pagination import PageNumberPagination ...
- DRF框架中链表数据通过ModelSerializer深度查询方法汇总
DRF框架中链表数据通过ModelSerializer深度查询方法汇总 一.准备测试和理解准备 创建类 class Test1(models.Model): id = models.IntegerFi ...
- DRF框架中的异常处理程序
目录 DRF框架中自定义异常处理 一.自定义异常的原因 二.如何设置处理异常的程序 DRF框架中自定义异常处理 一.自定义异常的原因 在Django和DRF框架中都封装了很多的处理异常的程序,可以处理 ...
- DRF框架中csrf异常
一.报错信息 "detail": "CSRF Failed: CSRF cookie not set." 二.解决办法 方法一: 在配置文件中配置 REST_F ...
随机推荐
- Django (七) token&静态文件&媒体文件
token&静态文件&媒体文件 1. token 1. 会话技术 2. 服务端会话技术 3. 它实际上就是手动实现的session 4. 实现token 4.1 在models.py中 ...
- Codeforces Round #533(Div. 2) A.Salem and Sticks
链接:https://codeforces.com/contest/1105/problem/A 题意: 给n个数,找到一个数t使i(1-n)∑|ai-t| 最小. ai-t 差距1 以内都满足 思路 ...
- MFC中的模态对话框与非模态对话框
模态对话框创建: MyDialog mydlg; mydlg.DoModal() 当前只能运行此模态对话框,且停止主窗口的运行,直到模态对话框退出,才允许主窗口运行. 模态对话框的关闭顺序: OnCl ...
- Django的filter查询
Django的filter查询 name__contains表示精确大小写的模糊查询 使用name__icontains表示忽略大小写 year_count = DownloadFile.object ...
- yii2 操作数据库
1.查询 User::find()->all(); 此方法返回所有数据: User::findOne($id); 此方法返回 主键 id=1 的一条数据(举个例子): User::find()- ...
- HTML 5的革新——更简洁的结构
今天我们阐述HTML 5的革新之一:更简洁的结构. 新的文档类型 DOCTYPE 先来解释一下文档类型 DOCTYPE:文档类型位于HTML源文件的第一行,在HTML4的标准中,DOCTYPE在被归在 ...
- JVM垃圾回收机制一
JVM内存分配与回收 JVM 分代 JVM把堆分为年轻代和老年代,年轻代又分为1个Eden区和2个Survivor区,Eden和Survivor的内存的大小比例是8:1:1. 为什么要分代? 很大的原 ...
- hihocoder1080 更为复杂的买卖房屋姿势
思路: 线段树区间修改,需要使用两个懒标记set和add.处理好两个标记的优先级即可(set之前的set和add是没有作用的). 实现: #include <bits/stdc++.h> ...
- js如何调用电脑的摄像头
闲来无事,用js写了一个调用摄像头的demo,并用canvas显示保存.这个功能很实用,比如上传用户的头像,即时拍照及时上传. Html: <video width="200px&qu ...
- CSS 中,用 float 和 position 的区别是什么?
CSS 中,用 float 和 position 的区别是什么? 呃,其实这个命题有误,只有position才是定位,float不能说是定位,不过你可以说这两种布局方式有什么不同.float和posi ...