urls:

from django.conf.urls import url
from app01 import views urlpatterns = [
# url(r"comment/$",views.Comment.as_view()),
url(r"comment/(?P<pk>\d+)",views.CommentDetailView.as_view()),
url(r"article/$",views.Article.as_view()),
url(r"school/(?P<id>\d+)",views.SchoolDetail.as_view(),name="school-detail"),
url(r"school_view/$",views.SchoolView.as_view(),name="school_view-detail"),
url(r"comment_view/$",views.CommentView.as_view(),name="comment_view-detail"),
url(r"article/(?P<pk>\d+)",views.ArticleDetail.as_view(),name="article-detail"), # url(r'comment/$',views.CommentViewSet.as_view({
# "get":"list",
# "put":"create",
# })),
#
# url(r'comment/(?P<pk>\d+)/$',views.CommentViewSet.as_view({
# "get":"retrieve",
# "put":"update",
# "delete":"destroy"
# })) ] from rest_framework.routers import DefaultRouter router = DefaultRouter()
router.register(r'comment',views.CommentViewSet)
urlpatterns += router.urls # 相当于 在urlpatterns里添加了:
# url(r'comment/$',views.CommentViewSet.as_view({
# "get":"list",
# "put":"create",
# })),
#
# url(r'comment/(?P<pk>\d+)/$',views.CommentViewSet.as_view({
# "get":"retrieve",
# "put":"update",
# "delete":"destroy"
# }))

views:此处为RESTful API 终极版:

from django.shortcuts import render,HttpResponse
from django.http import JsonResponse
from app01 import models
from rest_framework import serializers
from django import views
from rest_framework.views import APIView
from rest_framework.response import Response
from app01 import serializers as app01_serializers
from rest_framework.generics import GenericAPIView
from rest_framework.mixins import ListModelMixin,CreateModelMixin,RetrieveModelMixin,UpdateModelMixin,DestroyModelMixin
from rest_framework.generics import GenericAPIView, RetrieveUpdateDestroyAPIView, ListCreateAPIView
from rest_framework.viewsets import ModelViewSet # ==================================================================
# 95天内容 # 第一种方式: # class CommentView(APIView):
# def get(self,request):
# query_set = models.Comment.objects.all()
# ser_obj = app01_serializers.CommentSerializer(query_set,many=True)
# return Response(ser_obj.data) # 使用封装类后: # class CommentView(GenericAPIView,ListModelMixin,CreateModelMixin):
"""
GenericAPIView
只需要配置
queryset 和 serializer_class 即可
""" # queryset = models.Comment.objects.all() # 指定queryset对象
# serializer_class = app01_serializers.CommentSerializer # 指定类序列化
#
# def get(self,request, *args, **kwargs):
# return self.list(request, *args, **kwargs) # list方法为 ListModelMixin内部封装的函数,其源码为:
# def list(self, request, *args, **kwargs):
# queryset = self.filter_queryset(self.get_queryset())
#
# page = self.paginate_queryset(queryset)
# if page is not None:
# serializer = self.get_serializer(page, many=True)
# return self.get_paginated_response(serializer.data)
#
# serializer = self.get_serializer(queryset, many=True)
# return Response(serializer.data)
# 其实质与之前我们使用APIView一样,
# post 同理 # def post(self,request, *args, **kwargs):
# print("评论区")
# return self.create(request, *args, **kwargs) # 评论详情: # class CommentDetailView(GenericAPIView,RetrieveModelMixin,DestroyModelMixin,UpdateModelMixin):
# queryset = models.Comment.objects.all()
# serializer_class = app01_serializers.CommentSerializer
#
# def get(self,request,pk):
# return self.retrieve(request,pk)
#
# def delete(self,request,pk):
# return self.destroy(request,pk)
#
# def perform_destroy(self, instance):
# "someting code"
# # 可以在删除之前做的一些操作
# instance.delete()
#
# def put(self,request,pk):
# return self.update(request,pk) class SchoolView(GenericAPIView,ListModelMixin):
queryset = models.Comment.objects.all()
serializer_class = app01_serializers.CommentSerializer def get(self,request,*args,**kwargs):
return self.list(request, *args,**kwargs) # 第二种方式
class CommentDetailView(RetrieveUpdateDestroyAPIView): # RetrieveUpdateDestroyAPIView 相当于封装了GenericAPIView
# RetrieveModelMixin,DestroyModelMixin,UpdateModelMixin 这四个
# 可以进行查看,更改和删除操作。
queryset = models.Comment.objects.all()
serializer_class = app01_serializers.CommentSerializer #
class CommentView(ListCreateAPIView):
# ListCreateAPIView:内封装了 ListModelMixin CreateModelMixin
queryset =models.Comment.objects.all()
serializer_class = app01_serializers.CommentSerializer # 第三种方式:
# 终极版:
class CommentViewSet(ModelViewSet):
queryset = models.Comment.objects.all()
serializer_class = app01_serializers.CommentSerializer

RESTful API终极版序列化封装的更多相关文章

  1. day71:drf:API接口&Restful API规范&Django Rest Framework&drf中的序列化和反序列化功能

    目录 1.web应用模式 2.API接口 3.Restful API规范 4.序列化 5.Django Rest Framework 1.drf的简单介绍 2.drf的特点 3.如何安装drf 4.d ...

  2. python 全栈开发,Day95(RESTful API介绍,基于Django实现RESTful API,DRF 序列化)

    昨日内容回顾 1. rest framework serializer(序列化)的简单使用 QuerySet([ obj, obj, obj]) --> JSON格式数据 0. 安装和导入: p ...

  3. rest-framework 序列化格式Restful API设计规范

    理解RESTful架构 Restful API设计指南 理解RESTful架构 越来越多的人开始意识到,网站即软件,而且是一种新型的软件. 这种"互联网软件"采用客户端/服务器模式 ...

  4. Chrome Restful Api 测试工具 Postman-REST-Client离线安装包下载,Axure RP Extension for Chrome离线版下载

    [Postman for Chrome 离线下载] Postman-REST-Client离线安装包,可直接在Chrome浏览器本地安装使用,可模拟各种http请求,Restful Api测试, CS ...

  5. Django编写RESTful API(一):序列化

    欢迎访问我的个人网站:www.comingnext.cn 关于RESTful API 现在,在开发的过程中,我们经常会听到前后端分离这个技术名词,顾名思义,就是前台的开发和后台的开发分离开.这个技术方 ...

  6. HTTP请求封装:Ajax与RESTful API

    一.HTTP请求 HTTP即超文本传输协议,用以进行HTML 文件. 图片文件. 查询结果等的网络传输. 一个完整的HTTP请求包括:请求行.请求头.空行和请求数据(请求数据可以为空) HTTP1.1 ...

  7. 转:一个Restful Api的访问控制方法(简单版)

    最近在做的两个项目,都需要使用Restful Api,接口的安全性和访问控制便成为一个问题,看了一下别家的API访问控制办法. 新浪的API访问控制使用的是AccessToken,有两种方式来使用该A ...

  8. (转)RESTful API 设计最佳实践

    原文:http://www.oschina.net/translate/best-practices-for-a-pragmatic-restful-api 数据模型已经稳定,接下来你可能需要为web ...

  9. RESTful Api 身份认证安全性设计

    REST是一种软件架构风格.RESTful Api 是基于 HTTP 协议的 Api,是无状态传输.它的核心是将所有的 Api 都理解为一个网络资源.将所有的客户端和服务器的状态转移(动作)封装到 H ...

随机推荐

  1. tp5.1 Env使用

    5.1版本取消了所有的系统常量,原来的系统路径变量改为使用Env类获取(需要引入think\facade\Env) echo "app_path=========".Env::ge ...

  2. Android------实现图片双击放大,缩小,左右滑动的多种方式

    项目中常常有图片浏览功能.像微信朋友圈图片浏览,QQ空间照片浏览 的功能. 实现图片双击放大,缩小,左右滑动等效果. 来看看我的效果图,希望能满足你的要求   前三个button按钮是参考网上的多种实 ...

  3. selenium 3.6.0 geckodriver的一次坑

    Traceback (most recent call last):  File "./se3.py", line 16, in <module>    dr=webd ...

  4. vue全家桶实现笔记本功能

    一个通过vue实现的练手小项目,数据保存和导出通过node进行处理 成品截图: 安装vue-cli,webpack: cnpm install webpack -g cnpm install vue- ...

  5. UVA-1149 Bin Packing (贪心)

    题目大意:给定n个物品的重量,无限个容量为m的箱子,每个箱子最多装两个物品,要把所有的物品都装下,最少需要多少个箱子. 题目分析:贪心策略:每次将最重和最轻的两个物品放到一个箱子里,如果装不下,则将最 ...

  6. xtrabackup备份之增量备份(二)

    测试了差不多一周的xtrabackup,本篇主要聊一下xtrabackup的增量备份.我一开始不是很了解,为什么每周都需要做全备份,每天都需要做增量备份,现在想想这个和技术无关.但是有一个新问题,如果 ...

  7. Location对象的页面跳转方法介绍

    JavaScript中使用location对象可以通过很多种方式改变浏览器的位置.最常用的方法应该是下面几种: demo.js 1 2 3 location.href = "http://w ...

  8. 古董留念 - Microsoft Office 4.2中文版

    Office 4.2是Office 95的前一个版本,最适合运行在Windows 3.x上,但即使是最新的Windows 7 32位版也是可以安装它的(不信你可以试试)! 原版以软盘为载体,安装一次需 ...

  9. 此文记录了我从研二下学期到研三上学期的找工历程,包括百度、腾讯、网易、移动、电信、华为、中兴、IBM八家企业的面试总结和心得--转

    感谢电子通讯工程的研究生学长为大家整理了这么全面的求职总结,希望进入通信公司和互联网公司做非技术类岗位的学弟学妹们千万不要错过哦~ ---------------------------原文分割线-- ...

  10. Protel画完原理图检查的时候出现了这些错误 #1 Error Multiple Net Identifiers

    Error Report For : Documents\Sheet1.Sch 24-Aug-2009 14:58:43 #1 Error Multiple Net Identifiers : She ...