Vue前后端参数传递(重要)
一般来说,大部分情况下springboot中controller只要参数名可以一一对应,就可以很方便的传递参数,但是如果前台给后台的参数非常复杂,涉及到多种类型,那么controller就无法智能的自动注入了let ProdOBJ={"productCode": "155","productName": "产品-徐","productList...
·
一般来说,大部分情况下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,就可以得到完整的对象
更多推荐
已为社区贡献2条内容
所有评论(0)