java前台传参json,后台用map或者实体对象接收
(一)前台传js对象,里面包含数组,后台用map接收
(1)第一种情况:数组里不包含js对象
var param ={};
param.id=id;
param.name=name;
var score = new Array();
score.push('1');
score.push('2');
param.score = score;
后台先用该方法将json字符串转成map
Map<String,Object> param=RequestParamToMap.convert(req);
方法为
public class RequestParamToMap {
public static final Map<String,Object> convert(HttpServletRequest request){
Map<String,Object> param=new HashMap<String, Object>();
Enumeration<String> e=request.getParameterNames();
String name="";
String str[]=null;
while(e.hasMoreElements()){
name=e.nextElement();
str=request.getParameterValues(name);
name=name.replace("[", "").replace("]", "");
if(str.length==1)
param.put(name, str[0].replaceAll("\"", "\\\"").replaceAll("\'", "\\\'").replaceAll("<", "<").replaceAll(">", ">"));
else{
for(int i=0;i<str.length;i++)
str[i]=str[i].replaceAll("\"", "\\\"").replaceAll("\'", "\\\'").replaceAll("<", "<").replaceAll(">", ">");
param.put(name, str);
}
}
return param;
}
}
但是该方法对上面的param.score并不能转好,需要进行下一步:
List<Object> list=new ArrayList<>();
if(param.get("score").getClass().getName().equals("java.lang.String")){
list.add(param.get("score"));
}else{
list.addAll(Arrays.asList((Object[])param.get("score")));
}
param.put("score", list); //现在param.score就是一个集合了,可以传到sql语句中
(2)第二种情况:数组里包含js对象
var param ={};
param.id=id;
param.name=name;
var score = new Array();
var p={};
p.id = id;
p.name=name;
score.push(JSON.stringify(p)); //把js对象序列化成字符串
var m={};
m.id = id;
m.name=name;
score.push(JSON.stringify(m));
param.score = score;
后台依然用该方法将json字符串转成map
Map<String,Object> param=RequestParamToMap.convert(req);
但是该方法对上面的param.score并不能转好,需要进行下一步:
List<Map<String,Object>> list=null;
if(param.containsKey("score")){
list=new ArrayList<Map<String,Object>>();
if(param.get("score").getClass().getName().equals("java.lang.String")){
list.add(ObjectMapperTool.mapper.readValue(param.get("score").toString(),Map.class)); }else{
String[] strArr=(String[])param.get("score");
for(String str:strArr)
list.add(ObjectMapperTool.mapper.readValue(str,Map.class));
}
}
param.put("score",list);//现在param.score就是一个集合了,可以传到sql语句中
(二)前台传js对象,里面包含数组,后台用实体对象接收
(1)第一种情况:数组里包含js对象
var param ={};
param.id=id;
param.name=name;
var score = new Array();
var p={};
p.id = id;
p.name=name;
score.push(p);
var m={};
m.id = id;
m.name=name;
score.push(m);
param.score = JSON.stringify(score); //把数组序列化成字符串
后台用Student实体类接收,因传的score是个字符串,用String接收
public class Student implements Serializable{
private static final long serialVersionUID = 1L;
private int id;
private String name;
private String score;
//get set 省略
}
但是score里包含id和name两个字段,这就需要用到一个实体类集合
public class Score implements Serializable{
private static final long serialVersionUID = 1L;
private int id;
private String name;
//get set 省略
}
后台这样处理:
List<Score> score= new ArrayList<>();
if (!ChkUtil.isEmpty(Student.getScore())) {
try{
Score [] s = ObjectMapperTool.mapper.readValue(Student.getScore(),Score[].class);
score= Arrays.asList(s);
}catch(Exception e){
jsonMap.put(FieldConstant.STATUS, NumberConstant.STATUS_ERROR);
jsonMap.put(FieldConstant.MSG, MsgConstant.DATA_TO_JSON_ERROR);
logger.info(MsgConstant.DATA_TO_JSON_ERROR);
JSONResponseUtil.buildCustomJSONDataResponse(resp, jsonMap);
return;
}
}
(1)第二种情况:数组里不包含js对象
var param ={};
param.id=id;
param.name=name;
var score = new Array();
score.push(11);
score.push(22);
param.score = JSON.stringify(score); //把数组序列化成字符串
后台用一个实体对象接收,不同的是后台不需要写一个实体类集合,当然也可以写
List<String> score= new ArrayList<>();
if (!ChkUtil.isEmpty(Student.getScore())) {
try{
String[] s = ObjectMapperTool.mapper.readValue(Student.getScore(),String[].class);
score= Arrays.asList(s);
}catch(Exception e){
jsonMap.put(FieldConstant.STATUS, NumberConstant.STATUS_ERROR);
jsonMap.put(FieldConstant.MSG, MsgConstant.DATA_TO_JSON_ERROR);
logger.info(MsgConstant.DATA_TO_JSON_ERROR);
JSONResponseUtil.buildCustomJSONDataResponse(resp, jsonMap);
return;
}
}
java前台传参json,后台用map或者实体对象接收的更多相关文章
- angularjs向后台传参,后台收不到数据
angularjs中封装了一个$http服务,用来请求远程资源 参见:HTTP API 其中封装过的$http.post和$http.get使用起来比较方便 后台是php,用$_POST['name' ...
- 关于Java函数传参以及参数在函数内部改变的问题——JAVA值传递与引用最浅显的说明!
看了很多关于阐述JAVA传参到底是值传递还是引用的问题,有些说得很肤浅让人感觉似懂非懂的感觉,但是好像又能解决一些问题,然后就止步了.还有一些则是,讲得很深奥,看着好像很有道理的样子,但是其实还是没怎 ...
- 浅谈对java中传参问题的理解
之前用的c/c++比较多,在c/c++中对于传参类型,无外乎就是传值.传引用.传指针这几种.但在java中,由于没有指针类型,其传参的方式也发生了相应的变化.在网上找了找,按我之前的理解,java中传 ...
- springboot之json传参(后台控制层如何接收和解析参数)
一般web端都是用form标签的形式进行表单提交到后台,后台控制层再用相应的实体对象去接收前端传来的json参数. 但是有时候前端界面很复杂,要传入后端的参数是各种标签里面的value值,这些值又是来 ...
- springMVC通过ajax传参到后台
JSON对象和JSON字符串 在SpringMVC环境中,@RequestBody接收的是一个Json对象的字符串,而不是一个Json对象.然而在ajax请求往往传的都是Json对象,用 JSON.s ...
- 再谈Java方法传参那些事
把一个变量带进一个方法,该方法执行结束后,它的值有时会改变,有时不会改变.一开始会觉得--“好神奇呀”.当我们了解java内存分析的知识后,一切都是那么简单明了了--“哦,这么回事呀”.但是今天的上机 ...
- java上传excel到后台解析入库
背景:最近需要做一个excel模板导入的功能,以便用户可以自己增删改查数据,当然,只有特别的用户才能有此权限,捋了捋思路,还是从前端写起 实现: 页面最后的效果如下,可以自己修改,删除,导入导出数据, ...
- RESTful Get方式传参json格式后端400 解决方案
前端采用vue+axios 后端采用spring boot restful 问题: 前端get 请求需要传递array 字段值 后端由于tomcat 版本问题,不支持url接受特殊字符包括 [] {} ...
- java 线程传参 方式
第一类:主动向线程传参 public class ThreadTest extends Thread { public ThreadTest() { } /** * 第一种通过构造方法来传递参数 ...
随机推荐
- Python基础学习-列表基本操作
列表:Python的“苦力”. 列表不同于元组和字条串的地方:列表是可变的——可以改变列表的内容,并且列表有很多有用的.专门的方法. 1.list函数 因为字符串不能像列表一样被修改,所有有时根 ...
- 如何计算并测量ABAP及Java代码的环复杂度Cyclomatic complexity
代码的环复杂度(Cyclomatic complexity,有的地方又翻译成圈复杂度)是一种代码复杂度的衡量标准,在1976年由Thomas J. McCabe, Sr. 提出. 在软件测试的概念里, ...
- IOS instancetype的使用好处
instancetype的类型表示上,跟id一样,可以表示任何对象类型 instancetype只能用在返回值类型上,不能像 id 一样用在参数类型上 instancetype 比 id 多一个好处 ...
- InnoDB多版本(MVCC)实现简要分析
转载自:http://hedengcheng.com/?p=148 基本知识 假设对于多版本(MVCC)的基础知识,有所了解.InnoDB为了实现多版本的一致读,采用的是基于回滚段的协议. 行结构 I ...
- C++STL之vector向量容器
vector向量容器 vector向量容器不但能向数组一样对元素进行随机访问, 还能在尾部插入元素 vector具有内存自动管理的功能, 对于元素的插入和删除, 可动态调整所占的内存空间 vect ...
- Family Gathering at Christmas(思维题)
Family Gathering at Christmas 时间限制: 1 Sec 内存限制: 128 MB提交: 13 解决: 4[提交] [状态] [讨论版] [命题人:admin] 题目描述 ...
- 2017.10.24 Java 详解 JVM 工作原理和流程
JVM工作原理和特点主要是指操作系统装入JVM是通过jdk中Java.exe来完成,通过下面4步来完成JVM环境. 1.创建JVM装载环境和配置 2.装载JVM.dll 3.初始化JVM.dll并挂界 ...
- 旧文备份:怎样利用好单片机上的存储器资源来实现OD的存储与访问
我们知道OD(对象字典)是CANopen的核心,所有功能都是围绕它开展的,是协议栈的数据中心,良好的OD实现是协议栈高效稳定运行的基础,而OD的实现最基本的一点就是怎么去保存它.因为OD的内容比较杂, ...
- 第5章 什么是寄存器—零死角玩转STM32-F429系列
第5章 什么是寄存器 集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/firege 本章参考资料 ...
- powerdesigner15 反向工程