什么是请求参数绑定
请求参数格式
默认是key/value格式,比如:http:xxxx?id=1&type=2
请求参数值的数据类型
都是字符串类型的各种值
请求参数值要绑定的目标类型
Controller类中的方法参数,比如简单类型、POJO类型、集合类型等。
SpringMVC内置的参数解析组件
默认内置了24种参数解析组件(ArgumentResolver)
什么是参数绑定?
就是将请求参数串中的value值获取到之后,在进行类型转换,然后将转换后的值赋值给Controller类中方法的形参,这个过程就是参数绑定
默认支持的参数类型(Servlet API支持)
Controller方法形参中可以随时添加如下类型的参数,处理适配器会自动识别并进行赋值。
-
HttpServletRequest
- 通过request对象获取请求信息
-
HttpServletResponse
- 通过response处理响应信息
-
HttpSession
- 通过session对象获取session中存放的对象
- InputStream、OutputStream
- Reader、Writer
-
Model/ModelMap
- ModelMap继承自LinkedHashMap,Model是一个接口,它们的底层实现都是同一个类(BindingAwareModelMap),作用就是向页面传递数据,相当于Request的作用,如下
绑定简单数据类型
简单类型参数绑定方式
简单类型指的就是8种基本类型数据以及它们的包装类,还有String类型。
在SpringMVC中,对于java简单类型的参数,推荐的参数绑定方式有两种:
- 直接绑定
- 注解绑定
直接绑定
要求
http请求参数的key和controller方法的形参名称一致
请求URL
http://localhose:8080/xxx/findItem?id=1
请求参数的key为id
Controller方法
Controller的形参为Interger id,它和请求参数的key一致,所以直接绑定成功
@RequestMapping(value = "/findItem")
public String findItem(Integer id) {
System.out.println("接收到的请求参数是:"+ id);
return "success";
}
HttpServletRequest
@RequestMapping("findUserById2")
public String findUserById2(Integer id, String name,Model model,HttpServletRequest request) {
System.out.println(MessageFormat.format("id:{0},name:{1}", request.getParameter("id"),request.getParameter("name")));
model.addAttribute("msg",MessageFormat.format("id:{0},name:{1}", request.getParameter("id"),request.getParameter("name")));
return "success";
}
除了HttpServletRequest,还支持HttpServletResponse、HttpSession、Model等。
注解绑定
要求
请求参数key和controller方法的形参名称不一致时,需要使用@RequestParam注解才能将请求参数绑定成功。
请求URL
http://localhost:8080/xxx/findItem?itemId=1
请求参数的key为itemId
Controller方法
Controller的形参为Integer id,它和请求的参数不一致,需要使用@RequestParam注解才能绑定成功
@RequestMapping(value = "/findItem")
// 通过@RequestParam注解绑定简单类型
public String findItem(@RequestParam("itemId") Integer id) {
System.out.println("接收到的请求参数是:"+ id);
return "success";
}
RequestParam注解介绍
value:参数名字,即入参的请求参数名字,如value="itemId"表示请求的参数中的名字为itemId的参数的值将传入
required:是否必须,默认是true,表示请求中一定要有响应的参数,否则将报;
http Status 400 - Required Integer parameter 'xxx' is not present
defaultValue:默认值,表示如果请求中没有同名参数时的默认值
@RequestMapping(value = "/findItem")
// 通过@RequestParam注解绑定简单类型
// 学习@RequestParam注解中的value、required、defaultValue属性
public String findItem (
@RequestParam(value = "itemId", required = true, defaultValue = "2") Integer id) { System.out.println("接收到的请求参数是:"+ id);
return "success";
}
绑定POJO类型
要求
控制器方法的参数类型是POJO类型。
要求表单中参数名称和POJO类的属性名称保持一致。
请求URL
http://localhost:8080/xxx/updateItem?id=!&name=iphone&price=1000
Controller方法
POJO定义:
Controller方法
@RequestMapping("/updateItem")
public String updateItem(Integer id,Items item) { System.out.println("接收到的请求参数是:"+ id);
System.out.println("接收到的请求参数是:"+ item);
return "success";
}
绑定包装POJO
包装POJO类,依然是一个POJO,只是说为了方便沟通,将POJO中包含另一个POJO的这种类,称之为包装POJO。
包装对象
public class ItemQueryVO {
//商品信息
private Items item;
}
页面定义(item-list.jsp)
查询条件:
<table width="100%" border=1>
<tr>
<td>商品名称:<input type="text" name="items.name" /></td>
<td><input type="submit" value="查询" /></td>
</tr>
</table>
Controller方法
测试方法:断点跟踪,查看vo中的item对象是否有值
使用简单类型数组接收参数
要求
通过HTTP请求批量传递简单类型数据的情况,Controller方法中可以用String[]或者POJO的String[]属性接收(二选一),但是不能使用集合接收。
请求URL
http://localhost:8080/xxx/deleteItem?id=1&id=2&id=3
Controller方法
@RequestMapping("/deleteItem")
public String deleteitem(Integer[] itemId){ return "success";
}
使用POJO类型集合或数组接收参数
要求
批量传递的请求参数,最终要使用List<POJO>来接收,那么这个List<POJO>必须放在另一个POJO类中。
接收商品列表的POJO
public class ItemQueryVO { // 商品信息
private Item item;
// 其他信息 // 商品信息集合
private List<Items> itemsList;
}
public class ItemQueryVO {
//商品信息
private Item item;
//商品信息集合,方式一
private List<Item> itemList;
//商品信息集合,方式二
//private Item[] itemList; public Item getItem() {
return item;
} public void setItem(Item item) {
this.item = item;
} public List<Item> getItemList() {
return itemList;
} public void setItemList(List<Item> itemList) {
this.itemList = itemList;
}
}
请求URL
http://localhost:8080/xxx/batchUpdateItem?itemsList[0].id=1&itemsList[0].name=iphone&itemsList[0].price=1000&itemsList[1].id=2&itemsList[1].name=华为&items[1].price=5000
Controller
@RequestMapping("/batchUpdateItem")
public String batchUpdateItem(ItemQueryVO vo) {
return "success";
}
自定义参数绑定
请求URL
http://localhost:8080/xxx/saveItem?date=2019-12-4
Controller方法
@RequestMapping("/saveItem")
public String saveItem(String date){
System.out.println("接收到的请求参数是:"+ date);
return "success";
}
但是如何将date参数的类型有String改为Date,则报错
自定义Converter
public class DateConverter implements Converter<String, Date> { @Override
public Date convert(String source) {
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
try {
return simpleDateFormat.parse(source);
} catch (ParseException e) {
e.printStackTrace();
}
return null;
}
}
配置Converter
在springmvc.xml中,进行以下配置
<!-- 加载注解驱动 -->
<mvc:annotation-driven conversion-service="conversionService"/>
<!-- 转换器配置 -->
<bean id="conversionService"
class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
<property name="converters">
<set>
<bean class="com.cyb.ssm.controller.converter.DateConverter"/>
</set>
</property>
</bean>