微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Django request.POST 、 request.body 、request.data使用

request.POST(只能获取表单数据) 、 request.body(获取非表单数据) 是django原生的属性,request.data(包含表单及非表单数据)则是DRF封装的属性

           表单数据:a = request.POST.get('a')   alist = request.POST.getlist('a')   Content-Type(请求头)为application/x-www-form-urlencoded(form表单认格式)

           非表单数据: str = request.body.decode()                                               Content-Type(请求头)为application/json(json格式),multipart/form-data(文件)等

                            或  data = json.loads(request.body)(将json数据转成python对象)

 

ajax请求:
        1.如果请求头中的: Content-Type: application/x-www-form-urlencoded   request.POST中才会有值(才会去request.body中解析数据)
        2.若1有,也不一定有值 必须有数据格式要求: name=alex&age=18&gender=男

    如:
        a. form表单提交 认就会满足上诉的1和2
            <form method...>
                input
            </form>

        b. ajax提交
            $.ajax({
                url:...
                type:POST,
                data:{
                    name:alex,
                    age=18,
                }     #认也会满足上诉1和2  请求头认为application/x-www-form-urlencoded 内部数据格式会转为上述情况
            })

           自定义ajax 情况一
           $.ajax({
                url:...
                type:POST,
                headers:{'Content-Type':"application/json"}  #json格式 导致request.POST获取不了数据 而request.body依旧存在数据
                data:{name:alex, age = 18}   #内部自动转换 name=alex&age=18  通过request.body.encode()获取字符串数据(中文会有编码问题)

           }) #即body有值 POST无值

           自定义ajax 情况二
           $.ajax({
                url:...
                type:POST,
                headers:{'Content-Type':"application/json"}  #json格式 导致request.POST获取不了数据 而request.body依旧存在数据
                data:JSON.stringfy{name:alex, age = 18}   #通过json.loads(request.body)获取字典数据(推荐写法)

           }) 
           

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐