Rest framework-request.data

request.POST与request.data

request.POST在发JSON数据的时候是取不到值的,只有发urlecoding数据form-data数据才会有值.REST已经对request再次封装了,发送JSONurlecoding,form-data等常用等常用的数据都封装到data里了,这样就解决了request.POST在发JSON数据`的时候是取不到值的情况

示例:接收POST请求

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才会有值
        # REST已经对request再次封装了,发送JSON,urlecoding,form-data等常用等常用的数据都封装到data里了,这样就解决了request.POST 在发JSON数据的时候是取不到值的情况
        print("data",request.data)
        print("POST",request.POST)
        return Response("post")

测试urlencoded数据:

image.png

print结果: data与POST都能收到urlencoded数据

data <QueryDict: {'1': ['2'], '2': ['1']}>
[05/Aug/2018 04:00:21] "POST /books/ HTTP/1.1" 200 6
POST <QueryDict: {'1': ['2'], '2': ['1']}>

测试JSON数据:

image.png

print结果:POST接收不到JSON数据

data {'1': 2, 'q': 2, 'x': 1}
POST <QueryDict: {}>
[05/Aug/2018 04:08:11] "POST /books/ HTTP/1.1" 200 6

测试form-data数据:

image.png

print结果: data与POST都能收到form-data数据

data <QueryDict: {'x': ['1'], 'y': ['2']}>
POST <QueryDict: {'x': ['1'], 'y': ['2']}>
[05/Aug/2018 04:10:19] "Ps

看request.data源码分析

Book为例

Django 启动后执行的urls.py最后都会执行的dispatch分发方法那,然后用户访问后在执行dispatch分发方法.

urlpatterns = [
    url(r'^admin/', admin.site.urls),

    url(r'^login/$', views.LoginView.as_view()),
    url(r'^courses/$', views.CourseView.as_view()),
    url(r'^publishes/$', views.PublishView.as_view()),
    url(r'^books/$',views.BookView.as_view()),

]

区分request

image.png

谁调用as_view,self就是谁,从urls.py中可以看出是我们自己写的视图BookView调用的as_view,那self.dispatch应该先去找自己的和继承的

class BookView(APIView):

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

BookView没有dispatch方法,继续去BookView继承的是APIView里边找;找到了

image.png

initialize_request这个方法返回的是一个新的request 对象

image.png
image.png
image.png

data里边的源码不在分析,意思大致是:

  1. 拿到你这次编码的请求格式
  2. 根据请求体(media_type)的格式解析数据 # media_type = self.content_type
  3. 最后调用request.data就是解析后的数据是字典格式
image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Python 面向对象Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对...
    顺毛阅读 4,238评论 4 16
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,138评论 1 32
  • 1.ios高性能编程 (1).内层 最小的内层平均值和峰值(2).耗电量 高效的算法和数据结构(3).初始化时...
    欧辰_OSR阅读 29,591评论 8 265
  • 为什么放着平坦的大道你不走 非要向着高山进发 你说高山在那里,它在招手 平凡之路很幸福,但卓越之路更有吸引力 为什...
    灰云压城阅读 291评论 0 2
  • 看了一晚上租房 这么累
    松小鼠姐姐阅读 191评论 0 0