一 、复习

1. CBV流程

class BookView(View):

     def get():
pass
def post():
pass #url(r'^books/', views.BookView.as_view()),
#url(r'^books/', View.as_view()),
#url(r'^books/', View.view),
一旦用户访问books:
View.view(request)==View.dispatch(request)==self.get(request)

2.Restframework下的APIView流程

class BookView(APIView(View)):

     def get():
pass
def post():
pass #url(r'^books/', views.BookView.as_view()),
#url(r'^books/', APIView.as_view()),
#url(r'^books/', View.view), 一旦用户访问books: View.view(request)==APIView.dispatch(request)====self.get(request) 3 新的request对象 def APIView.dispatch(request):
request = self.initialize_request(request, *args, **kwargs)
request._request.GET
request._request.POST
request.POST
request.GET
request.data(针对post请求,put/patch)

  

3.序列化组件

from rest_framework import serializers

class BookSerializers(serializers.Serializer):
title=serializers.CharField(max_length=)
price=serializers.DecimalField(max_digits=,decimal_places=)
publish=serializers.CharField(max_length=,source="publish.name")
#authors=serializers.CharField(max_length=,source="authors.all")
authors=serializers.SerializerMethodField()
def get_authors(self,obj):
temp=[]
for obj in obj.authors.all():
temp.append(obj.name)
return temp '''
bs=BookSerializers(book_list,many=True)
temp=[]
for obj in book_list: temp.append({
'title':obj.title,
'price':obj.price,
'publish':obj.publish.name,
'authors':
}) bs.data=json.dumps(temp) ''' class BookView(APIView): def get(self,request): book_list=Book.objects.all()
bs=BookSerializers(book_list,many=True) # [{},{},{}]
bs1=
BookSerializers(model_obj) # {} return Response(bs1.data) def post(self, request): print("request.data",request.data)
print("request.data",request.data["title"])
print("request.POST",request.POST) return HttpResponse("post.....")

 二 、 RestFramwork之序列化组件1(get请求) .    

from django.shortcuts import render,HttpResponse,redirect

# Create your views here.
from django.views import View
from app01.models import Book
import json from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework import serializers """
有了modelSerializer后以下的代码都没用啦 。
from rest_framework import serializers class BookSerializers(serializers.Serializer):
title =serializers.CharField(max_length=32)
price =serializers.DecimalField(max_digits=8,decimal_places=2)
publish =serializers.CharField(max_length=32,source="publish.Email")
# authors =serializers.CharField(max_length=32,source="authors.all")
authors =serializers.SerializerMethodField()
def get_authors(self,obj):
temp =[]
for obj in obj.authors.all():
temp.append(obj.name)
return temp """ """
#总结的源码
bs =BookSerializers(book_list,many=True)
temp=[]
for obj in book_list:
temp.append({
’titlte':obj.title,
’price':obj.price,
’publish':obj.publish.name,
'authors':obj.authors. })
#总结的源码 bs.data =json.dumps(temp)
""" from rest_framework.serializers import ModelSerializer
class BookModelSerializers(ModelSerializer):
class Meta:
model =Book
fileds ="__all__"
authors =serializers.SerializerMethodField()
def get_authors(self,obj):
temp =[]
for obj in obj.authors.all():
temp.append(obj.name)
return temp class BookView(APIView):
"""
get请求:获取所有的书籍
post请求:添加一本书籍
"""
def get(self,request):
book_list =Book.objects.all()
bs =BookModelSerializers(book_list,many= True) return Response(bs.data) """
def get(self,request):
print(request._request.GET)
print(request.GET)
print(request.query_params) book_list= Book.objects.all()
# 方式一:
temp=[]
from django.forms.models import model_to_dict
# for book in book_list:
# temp.append(model_to_dict(book)) #序列化方式一 django提供的. #方式二:
# from django.core.serializers import serialize
# data =serialize("json",book_list) #序列化方式二 django提供的.
# return Response(data) #方式三:
bs =BookSerializers(book_list,many=True)
print("bs:is",bs) return Response(bs.data)
""" class BookDetailView(View):
pass

以上代码有问题打印不出来 publish 和author字段的内容.

三、RestFramwork之序列化组件2(POST请求 添加数据). 

查看红颜色部分为post请求

from rest_framework.serializers import ModelSerializer
class BookModelSerializers(ModelSerializer):
class Meta:
model =Book
fields ="__all__"
authors =serializers.SerializerMethodField()
def get_authors(self,row):
temp =[]
for i in row.authors.all():
print(i.name)
temp.append({'id':i.id,'name':i.name})
return temp
class BookView(APIView):
"""
get请求:获取所有的书籍
post请求:添加一本书籍
"""
def get(self,request):
book_list =Book.objects.all()
bs =BookModelSerializers(instance=book_list,many= True)
print(bs.data)
return Response(bs.data)
def post(self,request):
bs =BookModelSerializers(data=request.data)
if bs.is_valid(): #校验字段接口
obj =bs.save() #创建记录接口create
return Response(bs.data) #序列化接口
return Response(bs.error)#序列化接口

  

三、RestFramwork之序列化组件3(GET请求 查询某一本书籍数据).

views文件


class BookDetailView(APIView):
"""
查询某一本书籍
"""
def get(self,request,id):
book =Book.objects.filter(pk=id).first()
print(id)
bs = BookModelSerializers(book)
print("bs.dataaaaa",bs.data)
return Response(bs.data)

  

url

from django.conf.urls import url
from django.contrib import admin from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^books/$',views.BookView.as_view()),
url(r"^books/(\d+)/$",views.BookDetailView.as_view())
注意$符号必须加上,否则会出错
]

三、RestFramwork之序列化组件4(PUT请求 修改某一本书籍数据).

class BookDetailView(APIView):
"""
查询某一本书籍
"""
def get(self,request,id):
book =Book.objects.filter(pk=id).first()
print(id)
bs = BookModelSerializers(book)
print("bs.dataaaaa",bs.data)
return Response(bs.data)   """
  修改某一本书籍
  """
def put(self,request,id):
book =Book.objects.filter(pk=id).first()
print(request.data) bs = BookModelSerializers(data=request.data,instance=book)
if bs.is_valid():
bs.save()# book.update(request.data) return Response(bs.data) else:
return Response(bs.errors)

四、RestFramwork之序列化组件5(delete请求 删除某一本书籍数据).

class BookView(APIView):
"""
get请求:获取所有的书籍
post请求:添加一本书籍
"""
def get(self,request):
book_list =Book.objects.all()
bs =BookModelSerializers(instance=book_list,many= True)
return Response(bs.data)
def post(self,request):
bs =BookModelSerializers(data=request.data)
if bs.is_valid(): #校验字段接口
obj =bs.save() #创建记录接口create
return Response(bs.data) #序列化接口
return Response(bs.error)#序列化接口 class BookDetailView(APIView):
"""
查询某一本书籍
"""
def get(self,request,id):
book =Book.objects.filter(pk=id).first()
print(id)
bs = BookModelSerializers(book)
print("bs.dataaaaa",bs.data)
return Response(bs.data) """
修改某一本书籍
"""
def put(self,request,id):
book =Book.objects.filter(pk=id).first()
print(request.data) bs = BookModelSerializers(data=request.data,instance=book)
if bs.is_valid():
bs.save()# book.update(request.data) return Response(bs.data) else:
return Response(bs.errors) """
删除某一本书籍
"""
def delete(self,request,id):
Book.objects.filter(pk=id).first().delete()
return Response()

from app01.models import Publish,Author
class PublishModelSerializers(ModelSerializer):
class Meta:
model =Publish
fields ="__all__" class PublishView(APIView):
"""
publishs : get请求 :获取所有的出版社
post请求:获取一个出版社
"""
def get(self,request): #查询所有数据
publish_list =Publish.objects.all()
bs =PublishModelSerializers(publish_list,many=True)
return Response(bs.data)#序列化接口 def post(self,request): #添加一条数据
bs =PublishModelSerializers(data=request.data)
if bs.is_valid():#校验字段接口
obj=bs.save()#创建记录接口create return Response(bs.data)#序列化接口 return Response(bs.errors)#序列化接口 class PublishDetailView(APIView):
def get(self,request,id): #查询一条数据
publish =Publish.objects.filter(pk=id).first()
bs =PublishModelSerializers(publish)
return Response(bs.data)
def put(self,request,id): #修改一条数据
publish =Publish.objects.filter(pk=id).first()
bs =PublishModelSerializers(data=request.data,instance=publish)
if bs.is_valid():
bs.save()# publish.update(request.data)
return Response(bs.data)
else:
return Response(bs.errors) def delete(self,request,id): #删除一条数据
Publish.objects.filter(pk=id).delete()
return Response()

(序列化结束)

五、RestFramwork之视图

视图函数进行封装 ,book 模型序列化,publish模型序列化 。。。。可以给他们进行封装所以引出了视图混合类(maxins)。

第一种封装 maxin 混合类

url文件 (红色部分)

from django.conf.urls import url
from django.contrib import admin from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^books/$', views.BookView.as_view()),
url(r"^books/(\d+)/$", views.BookDetailView.as_view()), #mixin增删改查方式使用的
url(r"^publishes/$", views.PublishView.as_view()),
url(r'^publishes/(\d+)/$', views.PublishDetailView.as_view()), url(r'^authors/$', views.AuthorsModelView.as_view({"get": "list", "post": "create"}), ),
url(r'^authors/(?P<pk>\d+)/$', views.AuthorsModelView.as_view({
'get': 'retrieve',
'put': 'update',
'delete': 'destroy'
}), ),

view文件

#通过mixins的第一种方式 查询增删改查#######################mixins#################################

from rest_framework import generics
from rest_framework import mixins class PublishModelSerializers(ModelSerializer):
class Meta:
model = Publish
fields = "__all__" class PublishView(mixins.ListModelMixin,
mixins.CreateModelMixin,
generics.GenericAPIView):
queryset=Publish.objects.all()
serializer_class =PublishModelSerializers
def get(self,request,*args,**kwargs):
return self.list(self,request,*args,**kwargs) def post(self,request,*args,**kwargs):
return self.create(request,*args,**kwargs) class PublishDetailView(mixins.UpdateModelMixin,
mixins.RetrieveModelMixin,
mixins.DestroyModelMixin,
generics.GenericAPIView):
queryset = Publish.objects.all()
serializer_class = PublishModelSerializers def get(self, request, *args, **kwargs):
return self.retrieve(self, request, *args, **kwargs) def put(self, request, *args, **kwargs):
return self.update(request,*args,**kwargs) def delete(self, request, *args,**kwargs):
return self.destroy(request,*args,**kwargs)

以上增删改查有点问题

第二种封装方式 (generic)

url

from django.conf.urls import url
from django.contrib import admin from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
# url(r'^books/$', views.BookView.as_view()),
# url(r"^books/(\d+)/$", views.BookDetailView.as_view()), #第一种查询方式
# url(r"^publishes/$", views.PublishView.as_view()),
# url(r'^publishes/(\d+)/$', views.PublishDetailView.as_view()),
#第二种查询方式
url(r"^publishes/$", views.PublishViewSet.as_view()),
url(r'^publishes/(\d+)/$', views.PublishDetailViewSet.as_view()),
#第三种查询方式(modelviewset)
# url(r'^authors/$', views.AuthorsModelView.as_view({"get": "list", "post": "create"}), ),
# url(r'^authors/(?P<pk>\d+)/$', views.AuthorsModelView.as_view({
# 'get': 'retrieve',
# 'put': 'update',
# 'delete': 'destroy'
# }), ), ]

views

# 通过Generics类的第二种方式增删改查#######################mixins【viewset】#################################

from rest_framework import mixins
from rest_framework import generics -----------------------------序列化操作---------------------------------- class BookModelSerializers(ModelSerializer):
class Meta:
model = Publish
fields = "__all__" class PublishModelSerializers(ModelSerializer):
class Meta:
model = Publish
fields = "__all__" ----------------------------增删改查------------------------------------ class BookViewSet(generics.ListCreateAPIView): #查看、增加
queryset = Book.objects.all()
serializer_class = BookModelSerializers class BookDetailViewSet(generics.RetrieveUpdateDestroyAPIView): #删除更新
queryset = Book.objects.all()
serializer_class = BookModelSerializers ===================================================================== class PublishViewSet(generics.ListCreateAPIView):
queryset = Publish.objects.all()
serializer_class = PublishModelSerializers class PublishDetailViewSet(generics.RetrieveUpdateDestroyAPIView):
queryset = Publish.objects.all()
serializer_class = PublishModelSerializers

第三种封装(modelviewset)

url文件(红色部分)

from django.conf.urls import url
from django.contrib import admin from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
# url(r'^books/$', views.BookView.as_view()),
# url(r"^books/(\d+)/$", views.BookDetailView.as_view()), #第一种查询方式
# url(r"^publishes/$", views.PublishView.as_view()),
# url(r'^publishes/(\d+)/$', views.PublishDetailView.as_view()), #第二种查询方式
url(r"^publishes/$", views.PublishViewSet.as_view()),
url(r'^publishes/(\d+)/$', views.PublishDetailViewSet.as_view()), #第三种查询方式(modelviewset)
# url(r'^authors/$', views.AuthorsModelView.as_view({"get": "list", "post": "create"}), ),
# url(r'^authors/(?P<pk>\d+)/$', views.AuthorsModelView.as_view({
# 'get': 'retrieve',
# 'put': 'update',
# 'delete': 'destroy'
# }), ),

views逻辑部分

#通过mixins的第二种方式 查询增删改查(进一步优化)#######################mixins【viewset】#################################

from rest_framework.viewsets import ModelViewSet

class AuthorModelSerializers(ModelSerializer):
class Meta:
model = Publish
fields = "__all__" class AuthorsModelView(ModelViewSet):
queryset = Author.objects.all()
serializer_class = AuthorModelSerializers

day 94 RestFramework序列化组件与视图view的更多相关文章

  1. DjangoRestFramework学习二之序列化组件、视图组件 serializer modelserializer

      DjangoRestFramework学习二之序列化组件.视图组件   本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组 ...

  2. 19.DjangoRestFramework学习二之序列化组件、视图组件

    一 序列化组件 首先按照restful规范咱们创建一些api接口,按照下面这些形式写吧: Courses --- GET ---> 查看数据----->返回所有数据列表[{},{},] C ...

  3. day 88 DjangoRestFramework学习二之序列化组件、视图组件

    DjangoRestFramework学习二之序列化组件.视图组件   本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组件 ...

  4. DjangoRestFramework学习二之序列化组件、视图组件

    本节目录 一 序列化组件 二 视图组件 三 xxx 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 序列化组件 首先按照restful规范咱们创建一些api接口,按照下面这些形式写吧: ...

  5. drf序列化组件之视图家族

    一.视图家族的分类 1.导入分类 from rest_framewok import views, generics, mixins, viewsets views:视图类 ​ 两大视图类:APIVi ...

  6. Django rest-framework框架-组件之视图

    视图: a. django class Test(View): ... b. rest_framework class Test(APIView): ... c. GenericAPIView 一般不 ...

  7. python全栈开发day99-DRF序列化组件

    1.解释器组件源码分析 https://www.processon.com/view/link/5ba0a8e7e4b0534c9be0c968 2.基于CBV的接口设计 1).django循环que ...

  8. rest-framework之APIView 序列化组件

    rest-framework之APIView 一 安装djangorestframework 方式一:pip3 install djangorestframework 方式二:pycharm图形化界面 ...

  9. rest-framework框架——APIView和序列化组件

    一.快速实例 Quickstart http://www.cnblogs.com/yuanchenqi/articles/8719520.html restful协议 ---- 一切皆是资源,操作只是 ...

随机推荐

  1. php不重新编译,安装未安装过的扩展,如curl扩展

    假设我们的之前的php安装于/data/php下. 1.找到之前安装的PHP源码包,把它重新解压出来,进入到要安装的扩展目录. > cd /data/php-5.6.11/ext/curl (* ...

  2. datagridview 如何禁止行被选中

    如题,如何规定特定的行,光标不能定位,也不能被选中,就好想Button中的Enable属性那样,变灰,而且点击也没有反应那种,这样的效果,如何实现. datagridview [解决办法]dataGr ...

  3. debuginfo介绍

    一.简介 深入理解debuginfo http://blog.csdn.net/chinainvent/article/details/24129311?reload 关于DWARF http://w ...

  4. SSH登录到远程linux机器并执行命令

    一. 1.JSch是Java Secure Channel的缩写.JSch是一个SSH2的纯Java实现.它允许你连接到一个SSH服务器,并且可以使用端口转发,X11转发,文件传输等,当然你也可以集成 ...

  5. linux c++连接mysql编译问题

  6. 用户体验要好,App动画得这么做

    以下内容由Mockplus团队翻译整理,仅供学习交流,Mockplus是更快更简单的原型设计工具.   在用户体验设计方面,App动画的设计和添加,带给设计师无限的创造空间的同时,也成为设计师群体最具 ...

  7. postman模拟登录接口

    https://blog.csdn.net/qq_22219911/article/details/80235272

  8. Confluence无法打开编辑器,一直在转圈

    在管理员界面中,将Collaborative editing 设置为Off 或者 Limited . 快速找到该界面的方式是,在搜索框里搜索 “Collaborative editing”. 折腾了几 ...

  9. nginx怎么与tomcat完美结合

    nginx怎么与tomcat完美结合 现在公司一个服务器上需要部署两个项目,其中一个项目已经正式上线,并且已经占用了80端口,另外一个项目 部署上去后,访问必须要加端口号,这样的用户体验非常不好,那么 ...

  10. 2018.06.28 BZOJ1014 [JSOI2008]火星人prefix(非旋treap+hash)

    [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MB Submit: 8951 Solved: 2860 Description 火星 ...