前端向后端传递json数据

  • 最近在使用ajax向后端传递数据时,遇到了一些问题,自己简单研究了一下,做个总结。

问题发现

  • 起初我的ajax请求是这样写的
        $("#error_data").click(function (){
            var url = "/show/test_json/";
            var data = {
                "list": [1,2],
                "name": "xxx",
                "text": "中国人"
            };

            $.ajax({
                url: url,
                data: data,
                type: "POST",
                contentType : "application/json",
                traditional: true,
                success: function(data) {
                    console.log(data);
                },
                error: function (data) {
                    console.log(data);
                }
            });
        });
  • 然后我发现我在后端接受到的数据是这样的
	print(request.POST)
    print(request.method)
    print(request.body)
<QueryDict: {}>
POST
b'list=1&list=2&name=xxx&text=%E4%B8%AD%E5%9B%BD%E4%BA%BA'
  • 当我准备给request.body解码后然后进行序列化,这个时候错误就发生了
json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)

问题解决

  • 在网上找了一些资料发现,问题原因在于,我没有对往后端传的数据,进行处理;
  • 需要将json对象转换为json字符串,然后在向后端传递
        $("#send_btn").click(function (){
            var url = "/show/test_json/";
            var data = {
                "list": [1,2],
                "name": "xxx",
                "text": "中国人"
            };

            $.ajax({
                url: url,
                data: JSON.stringify(data),
                type: "POST",
                contentType : "application/json",
                dataType: "text",
                traditional: true,
                success: function(data) {
                    console.log(data);
                    console.log(JSON.parse(data));

                },
                error: function (data) {
                    console.log(JSON.parse(data));
                }
            });

        });
  • 后端接收到的数据
<QueryDict: {}>
POST
b'{"list":[1,2],"name":"xxx","text":"\xe4\xb8\xad\xe5\x9b\xbd\xe4\xba\xba"}'
  • 这样后端就可以对request.body内容解码后,进行序列化了。

问题总结

  • 前端向后端传递json数据时,需要使用JSON.stringify()将json对象转化为json字符串。
  • Django后端接收前端传递过来的json数据,不能使用request.POST而是要使用request.body
  • request.body的数据为bytes类型,要想使用,需要先解码。
  • 5
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值