Vue前后端参数传递(重要)

一般来说,大部分情况下springboot中controller只要参数名可以一一对应,就可以很方便的传递参数,但是如果前台给后台的参数非常复杂,涉及到多种类型,那么controller就无法智能的自动注入了

let ProdOBJ={
        "productCode": "155",
        "productName": "产品-徐",
        "productListCode": "list-xu",
        "productListName": "徐-列表",
        "pstCode": "DATA",
        "pstName": "数据",
        "productAttr": [{
          "attrID": "1141",
          "attrName": "地址2",
          "attrValueType": "xxx",
          "attrSource": "xxx",
          "defaultValue": "xxx",
          "DispersedValue": "",
          "attrValueRule": "ttt",
          "remark": "zzz"
        }],
        "actionOBJ": [{
          "actionID": "0",
          "actionName": "动作-徐",
          "actionType": "xu-action"
        }],
        "productRelation": [{
          "proRelationID": "13",
          "proRelationType": "1",
          "AproCode": "2",
          "AproName": "3",
          "ZproCode": "4",
          "ZproName": "5"
        }],
        "actionLimit": [{
          "actionID": "0",
          "actionName": "1",
          "attrID": "2",
          "attrName": "3",
          "attrLimit": "4"
        }],
        "remark": "五"
      }

这种情况下如何处理?
第一步,controller的方法接收参数时要使用string

public ResponseEntity<String> saveControlelr(@RequestBody(required = true)String ProdOBJ)

此时收到的是一个完整的json字符串
注意:JSON必须格式正确,如果不知道怎么调整,可以百度JSON格式化
第二步,手动解析JSON字符串

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
ProdObjAccept demObjAccept = JSON.parseObject(ProdOBJ, ProdObjAccept.class);

注意,json的方法有很多,这种写法一定只能是阿里的fastjson
这样一来,就可以拆掉第一层stringify
再用同样的方法拆各个数组的stringify,就可以得到完整的对象

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值