Rest framework-视图组件

REST之视图

GET :从服务器取出资源(一项或多项)
POST :在服务器新建一个资源
PUT :在服务器更新资源(客户端提供改变后的完整资源)
PATCH :在服务器更新资源(客户端提供改变的属性)
DELETE :从服务器删除资源

book为例:

"books/$"   GET:获取所有数据  
            POST:添加一条数据

"Book/1"    GET:获取单条数据  
            DELETE:删除一条数据   
            PUT/PATCH:更新一条数据

不加id的url

获取数据

url.py

    url(r'^books/$',views.BookView.as_view()),

serializer.py

from app01.models import Book
class BookSerializers(serializers.ModelSerializer):
   class Meta:
       model=Book
       # 序列化所有数据,与exclude不能并存
       fields="__all__"

   # # 这样加上去之后,就是不要他创建的字段了,用我自己写的自定义字段,有的话覆盖,没有的话添加
   # 
   # publish=serializers.CharField(source='publish.name',read_only=True)
   # 
   # # SerializerMethodField 声明这是个多对多字段
   # authors=serializers.SerializerMethodField(read_only=True)
   # # 声明好多对多字段,底下紧跟着定义一个方法
   # # 此时的obj就是你循环book_list的obj对象
   # def get_authors(self,obj):
   #     data=[]
   #     # for 循环 对象关联Author表所有的对象
   #     for i in obj.authors.all():
   #         temp = []
   #         temp.append(i.pk)
   #         temp.append(i.name)
   #         data.append(temp)
   #     return data

views.py

from rest_framework.views import  APIView
from app01.serializer import PublishSerializers,BookSerializers
from app01.models import Book

class BookView(APIView):

    def get(self,request):
        book_list=Book.objects.all()
        ps=BookSerializers(book_list,many=True)
        # 序列化完成的数据
        return Response(ps.data)

添加一条数据

请先阅读上一篇文章:Rest framework-request.data

views.py

class BookView(APIView):

    def get(self,request):
        book_list=Book.objects.all()
        ps=BookSerializers(book_list,many=True)
        # 序列化完成的数据
        return Response(ps.data)

    def post(self,request):
        # 添加一条数据
        # request.POST 在发JSON数据的时候是取不到值的,只有发urlecoding,orm-data才会有值
        # REST已经对request再次封装了,发送JSON,urlecoding,form-data等常用等常用的数据都封装到data里了,这样就解决了request.POST 在发JSON数据的时候是取不到值的情况
        print("data",request.data)
        print("POST",request.POST)
        # 生成一条记录
        bs=BookSerializers(data=request.data)
        # 校验成功后生成记录
        if bs.is_valid():
            bs.save()
            # 把添加的数据序列化返回
            return Response(bs.data)
        else:
            # 校验失败返回错误信息
            return Response(bs.errors)

image.png
image.png

加id的url

"books/$"   GET:获取所有数据  
            POST:添加一条数据
# 上边的我们上边已经演示过了
"Book/1"    GET:获取单条数据  
            DELETE:删除一条数据   
            PUT/PATCH:更新一条数据

urls.py

url(r'^books/$',views.BookView.as_view()),
# ?P<> 分组 
url(r'^books/(?P<pk>\d+)/$',views.BookDetailView.as_view()),

views.py

from rest_framework.views import  APIView
from app01.models import Book

class BookView(APIView):

    def get(self,request):
        book_list=Book.objects.all()
        ps=BookSerializers(book_list,many=True)
        # 序列化完成的数据
        return Response(ps.data)
    def post(self,request):
        # 添加一条数据
        # request.POST 在发JSON数据的时候是取不到值的,只有发urlecoding,orm-data才会有值
        # REST已经对request再次封装了,发送JSON,urlecoding,form-data等常用等常用的数据都封装到data里了,这样就解决了request.POST 在发JSON数据的时候是取不到值的情况
        print("data",request.data)
        print("POST",request.POST)
        # 生成一条记录
        bs=BookSerializers(data=request.data)
        # 校验成功后生成记录
        if bs.is_valid():
            bs.save()
            # 把添加的数据序列化返回
            return Response(bs.data)
        else:
            # 校验失败返回错误信息
            return Response(bs.errors)

class BookDetailView(APIView):

    def get(self,request,pk):
        # 根据pk值获取数据库对应的一条对象
        book_obj=Book.objects.filter(pk=pk).first()
        # 序列化一个对象,默认就为False
        bs=BookSerializers(book_obj,many=False)
        return Response(bs.data)

    def put(self,request,pk):
        book_obj=Book.objects.filter(pk=pk).filter()
        # 更新一定要传两个值
        # 第一个这次更新传进来的数据(data=request.data)
        # 第二个要更新的对象(instance=book_obj)
        bs=BookSerializers(data=request.data,instance=book_obj)
        if bs.is_valid():
            # 如果校验成功就updata
            bs.save()
            # 返回更新后的数据
            return Response(bs.data)
        else:
            # 返回错误信息
            return Response(bs.errors)

    def delete(self,request,pk):
        Book.objects.filter(pk=pk).delete()
        return Response("OK")

GET:http://127.0.0.1:8000/books/2/

image.png

PUT:http://127.0.0.1:8000/books/2/

image.png

DELETE:http://127.0.0.1:8000/books/2/

image.png

现在我们在来看下所有数据


image.png

额外知识

Django seetings.py配置文件中默认没有 APPEND_SLASH 这个参数,但 Django 默认这个参数为 APPEND_SLASH = True。 作用就是自动在网址结尾加'/'。
默认地,任何不匹配或尾部没有斜杠(/)的申请URL,将被重定向至尾部包含斜杠的相同字眼的URL。
seetings.py 设置为 APPEND_SLASH = False 时,访问 网址最后不加/ 将会返回 404

1、第一次路径匹配成功该返回什么返回什么
2、如果:第一次路径匹配发现匹配不成功,但是再带个/就就匹配成功了,Django会告诉路由器你再带个url后面再加个/过来get请求发过来吧,所以是发了两次请求,你仔细看下url地址栏的变化


image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容