天天看点

成功解决: django获取 ajax POST 数据失败

问题

  • 在使用ajax POST 向后台发送数据的时候,后台接收不到,初始代码如下:
// 前端:
    $.ajax({
    ...
    data: {name: {k1: v1, k2: v2}, xx: [1, [1, 2]]}
    })      
# Django后台:
    request.POST
    request.POST.get('name')
    request.POST.get('xx')      

解决方法

  • ajax POST 发送简单的数据后台是可以接收到的,比如下面简单的字典和列表后台就能接收到。
// 前端:
    $.ajax({
    ...
    data: {name: 1, age: 2, xx=[1, 2, 3]}
    })
    $.post(url, data, callback)      
# Django后台:
    request.POST
    request.POST.get('name')
    request.POST.get('age')
    request.POST.getlist('xx')      
  • 但是,如果数据比较复杂,比如字典中套着字典、列表等,ajax POST发送到后台是请求不到的,这时候需要将数据转化为 json 字符串再发送到后端。在后台先通过​

    ​request.body​

    ​​获取前端发来的数据,再进行​

    ​utf-8​

    ​​接码,最后通过​

    ​json.loads()​

    ​ 将json 字符串转化为字典即可。如下:
前端:
    $.post(url, JSON.stringfy({name: {k1: v1, k2: v2}, xx: [1, [1, 2]]}), function (data) {});      
Django后台:
    request.body
    info = json.loads(request.body.decode('utf-8'))
    info['name']
    info['xx']