SpringMVC如何接收参数各种场景

作者:冲动的仔bb 时间:2022-01-23 22:56:24 

表单提交

此处的表单时 -使用JSON.stringify()函数将数组转换成json类型提交后台,后台使用@RequestBody User user接受处理

页面js


//新增提交按钮
$("#buildsubmit").click(function() {
  var param = $(".form").serializeJson();
  $.ajax({
   type: 'post',
   url: path + "/web/member/save.do",
   contentType: "application/json",
   dataType: 'json',
   data: JSON.stringify(param),
   success: function(data) {

},
  });
 }
});

后端代码


@RequestMapping(value = "/save", method = RequestMethod.POST)
public GeneralResponse save(@RequestBody @Valid MemberInsertDetail member, BindingResult bindingResult)
  throws JsonProcessingException {
 if (bindingResult.hasErrors()) {
  throw new ErrParamException();
 }
 boolean flag = false;
 flag = memberService.save(member);
}

表单提交二

使用.serialize()方法 提交表单内容;

1、可以后台使用 request.getParamter("对应字段的name")获取参数;

2、也可以使用 Model mdel 的POJO接受。(name要一一对应起来)

  • 格式:var data = $("#formID").serialize();

  • 功能:将表单内容序列化成一个以&拼接的字符串,键值对的形式,name1=val1&name2=val2&,空格以%20替换。

页面JS


function sub(){
$.ajax({
 type:"post",
 url:"/restaurant/addEmployees.do",
 data:$("#form").serialize(),
 dataType :"json",
 success:function(data){
  if(!data.success){
 }
});
}

页面html代码:


<form action="" id="staff_form">
<div class="addInfor">
<input type="" name="phone" id="phone" value="" placeholder="请输入手机号"/>
<input type="" name="password" id="password" value="" placeholder="请输入密码"/>
<input type="" name="username" id="username" value="" placeholder="请输入姓名"/>

<input name="checkbox" value="chief_store_member" type="checkbox" >
<label class="grey-font" >多店管理</label>
<input name="checkbox" value="branch_store_member" type="checkbox">
<label class="grey-font" >单店管理</label>
</div>
<button type="button" class="mui-btn orange-btn" οnclick="sub();">确认</button>
</form>

后台代码接收方式一

含有单个的checkbox参数接收


@RequestMapping("/addEmployees")
@ResponseBody
public Result<Integer> addEmployees(HttpServletRequest request) {
 String phone = request.getParameter("phone");
 String password = request.getParameter("password");
 String username = request.getParameter("username");
 身份单checkbox接收。如果是复选框多个checkbox,则用数组String[] 接收。
 String checkbox = request.getParameter("checkbox");
}

后台代码接收方式二


@RequestMapping(value="/addCustomer",method=RequestMethod.POST)
@ResponseBody
public LogisticsResult addCustomer(@Valid CustomerInfo customer,BindingResult result ){
       如果是复选框多个checkbox,则在pojo中 用与checkbox的name一样的 数组接收。
       如: String[] checkbox;
}

接收List<String>集合参数:

1、页面js代码:


var idList = new Array();  
idList.push(“1”);  
idList.push(“2”);  
idList.push(“3”);  
var isBatch = false;  
$.ajax({  
   type: "POST",  
   url: "<%=path%>/catalog.do?fn=deleteCatalogSchemes",  
   dataType: 'json',  
   data: {"idList":idList,"isBatch":isBatch},  
   success: function(data){  
       …  
   },  
   error: function(res){  
       …  
   }  
});  

2、Controller方法:


@Controller  
@RequestMapping("/catalog.do")  
public class CatalogController {    
   @RequestMapping(params = "fn=deleteCatalogSchemes")  
   @ResponseBody  
   public AjaxJson deleteCatalogSchemes(@RequestParam("idList[]") List<String> idList,Boolean isBatch) {
           …  
   }  
}

接收List<User>、User[]集合参数:

1、User实体类:


public class User {  
       private String name;  
   private String pwd;  
   //省略getter/setter  
}

2、页面js代码:


var userList = new Array();  
userList.push({name: "李四",pwd: "123"});  
userList.push({name: "张三",pwd: "332"});  
$.ajax({  
   type: "POST",  
   url: "<%=path%>/catalog.do?fn=saveUsers",  
   data: JSON.stringify(userList),//将对象序列化成JSON字符串  
   dataType:"json",  
   contentType : 'application/json;charset=utf-8', //设置请求头信息  
   success: function(data){  
       …  
   },  
   error: function(res){  
       …  
   }  
});

3、Controller方法:


@Controller  
@RequestMapping("/catalog.do")  
public class CatalogController {    
   @RequestMapping(params = "fn=saveUsers")  
   @ResponseBody  
   public AjaxJson saveUsers(@RequestBody List<User> userList) {  
       …  
   }  
}

如果想要接收User[]数组,只需要把saveUsers的参数类型改为@RequestBody User[] userArray就行了。

接收List<Map<String,Object>>集合参数:

1、页面js代码(不需要User对象了):


var userList = new Array();  
userList.push({name: "李四",pwd: "123"});  
userList.push({name: "张三",pwd: "332"});  
$.ajax({  
   type: "POST",  
   url: "<%=path%>/catalog.do?fn=saveUsers",  
   data: JSON.stringify(userList),//将对象序列化成JSON字符串  
   dataType:"json",  
   contentType : 'application/json;charset=utf-8', //设置请求头信息  
   success: function(data){  
       …  
   },  
   error: function(res){  
       …  
   }  
});

2、Controller方法:


@Controller  
@RequestMapping("/catalog.do")  
public class CatalogController {  

@RequestMapping(params = "fn=saveUsers")  
   @ResponseBody  
   public AjaxJson saveUsers(@RequestBody List<Map<String,Object>> listMap) {  
       …  
   }  
}

接收User(bean里面包含List)集合参数:

1、User实体类:


public class User {  
   private String name;  
   private String pwd;  
   private List<User> customers;//属于用户的客户群  
   //省略getter/setter  
}

2、页面js代码:


var customerArray = new Array();  
customerArray.push({name: "李四",pwd: "123"});  
customerArray.push({name: "张三",pwd: "332"});  
var user = {};  
user.name = "李刚";  
user.pwd = "888";  
user. customers = customerArray;  
$.ajax({  
   type: "POST",  
   url: "<%=path%>/catalog.do?fn=saveUsers",  
   data: JSON.stringify(user),//将对象序列化成JSON字符串  
   dataType:"json",  
   contentType : 'application/json;charset=utf-8', //设置请求头信息  
   success: function(data){  
       …  
   },  
   error: function(res){  
       …  
   }  
});

3、Controller方法:


@Controller  
@RequestMapping("/catalog.do")  
public class CatalogController {  
   @RequestMapping(params = "fn=saveUsers")  
   @ResponseBody  
   public AjaxJson saveUsers(@RequestBody User user) {  
       List<User> customers = user.getCustomers();  
       …  
   }  
}

来源:https://blog.csdn.net/victoylin/article/details/79803546

标签:SpringMVC,接收参数,场景
0
投稿

猜你喜欢

  • 详解MyBatis的Dao层实现和配置文件深入

    2022-07-26 02:29:17
  • java中初始化MediaRecorder的实现方法

    2023-11-29 03:54:52
  • Java编程复用类代码详解

    2021-09-13 10:06:34
  • 学习Java的Date、Calendar日期操作

    2023-09-04 22:26:38
  • Java实现经典游戏黄金矿工的示例代码

    2022-01-09 16:35:41
  • java类加载机制、类加载器、自定义类加载器的案例

    2023-02-06 07:35:33
  • java实现倒序读取文件功能示例分享

    2023-07-12 09:23:54
  • Java之如何关闭流

    2023-11-04 21:29:11
  • android中使用SharedPreferences进行数据存储的操作方法

    2023-06-16 17:37:42
  • bool当成函数参数错误理解

    2021-07-30 09:27:18
  • 全面分析Java文件上传

    2021-12-09 13:22:52
  • 推荐两款java开发实用工具 hutool 和 lombok

    2022-04-06 10:20:14
  • 浅谈Java中Map和Set之间的关系(及Map.Entry)

    2023-08-25 02:23:48
  • java反编译工具Bytecode-Viewer分享

    2021-05-29 04:39:07
  • springcloud 如何解决微服务之间token传递问题

    2022-08-27 18:43:48
  • spring security动态配置url权限的2种实现方法

    2021-06-25 15:31:12
  • java使用JNA(Java Native Access)调用dll的方法

    2022-02-06 09:27:34
  • C#.net实现在Winform中从internet下载文件的方法

    2023-09-13 18:04:15
  • java实现酒店管理系统

    2023-06-09 23:59:50
  • JavaFX实现UI美观效果代码实例

    2021-08-27 21:02:15
  • asp之家 软件编程 m.aspxhome.com