https://blog.csdn.net/bocai_xiaodaidai/article/details/113257842
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)获取字典数据(推荐写法)
})
————————————————
版权声明:本文为CSDN博主「蓝绿色~菠菜」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/bocai_xiaodaidai/article/details/113257842