1. 基本类型参数
包括基本类型和String类型。要求我们的参数名称必须和控制器中方法的形参名称保持一致(严格区分大小写)。
页面代码:
<a href="account/findAccount?accountId=10&accountName=zhangsan">查询账户</a>
控制器代码:
@Controller("account")
public class AccountController {
@RequestMapping("/findAccount")
public String findAccount(Integer accountId, String accountName) {
System.out.println(accountId+","+accountName);
return "success";
}
}
2. POJO类型参数
包括实体类,以及关联的实体类。要求表单中参数名称和POJO类的属性名称保持一致,并且控制器方法的参数类型是POJO类型。
POJO类代码:
public class Account implements Serializable {
private Integer id;
private String name;
private Float money;
private Address address;
//省略 getters和 setters
}
public class Address implements Serializable {
private String provinceName;
private String cityName;
//省略 getters and setters
}
页面代码:
<form action="account/saveAccount" method="post">
账户名称: <input type="text" name="name" ><br/>
账户金额: <input type="text" name="money" ><br/>
账户省份: <input type="text" name="address.provinceName" ><br/>
账户城市: <input type="text" name="address.cityName" ><br/>
<input type="submit" value="保存">
</form>
控制器代码:
@Controller("account")
public class AccountController {
@RequestMapping("/saveAccount")
public String saveAccount(Account account) {
System.out.println("保存了账户:" + account);
return "success";
}
}
3. 数组和集合类型参数
包括数组和List结构与Map结构的集合。要求
- 第一种:要求集合类型的请求参数必须在POJO中,在表单中请求参数名称要和POJO中集合属性名称相同。给List集合中的元素赋值,使用下标。给Map集合中的元素赋值,使用键值对。
- 第二种:接收的请求参数是json格式数据。需要借助@RequestBody注解实现。
POJO类代码:
public class User implements Serializable {
private String username;
private String password;
private Integer age;
private Integer[] ids
private List<Account> accountsList;
private Map<String,Account> accountMap;
//省略 getters和 setters
}
页面代码:
<form action="account/updateAccount" method="post">
用户名称: <input type="text" name="username" ><br/>
用户密码: <input type="password" name="password" ><br/>
用户年龄: <input type="text" name="age" ><br/>
用户ids: <input type="text" name="ids" ><br/>
用户ids: <input type="text" name="ids" ><br/>
账户 1 名称: <input type="text" name="accountsList[0].name" ><br/>
账户 1 金额: <input type="text" name="accountsList[0].money" ><br/>
账户 2 名称: <input type="text" name="accountsList[1].name" ><br/>
账户 2 金额: <input type="text" name="accountsList[1].money" ><br/>
账户 3 名称: <input type="text" name="accountMap['one'].name" ><br/>
账户 3 金额: <input type="text" name="accountMap['one'].money" ><br/>
账户 4 名称: <input type="text" name="accountMap['two'].name" ><br/>
账户 4 金额: <input type="text" name="accountMap['two'].money" ><br/>
<input type="submit" value="保存">
</form>
控制器代码:
@Controller("account")
public class AccountController {
@RequestMapping("/updateAccount")
public String updateAccount(User user) {
System.out.println("更新了账户:" + user);
return "success";
}
}
4. 自定义类型转换器
开发过程中我们可能还会遇到需要我们自己定义类型转换器的情况,例如前端传入了一个String类型的字符串,而接口中希望以日期类型接收该参数,如下所示:
页面代码:
<a href="account/deleteAccount?date=2018-01-01">用于把String类型转成日期类型</a>
控制器代码:
@Controller("account")
public class AccountController {
@RequestMapping("/deleteAccount")
public String deleteAccount(Date date) {
System.out.println("传入的日期为:" + date);
return "success";
}
}
这种情况下,由于SpringMVC不能把String类型转成日期类型而报错,我们可以使用SpringMVC自定义类型转换器来进行参数的转换。
定义一个类,实现Converter接口,该接口有两个泛型,第一个表示接受的类型,第二个表示目标类型。具体如下所示:
//用于把 String类型转成日期类型
public class StringToDateConverter implements Converter<String, Date> {
@Override
public Date convert(String source) {
DateFormat format = null;
try {
if(StringUtils.isEmpty(source)) {
throw new NullPointerException("请输入要转换的日期");
}
format = new SimpleDateFormat("yyyy-MM-dd");
Date date = format.parse(source);
return date;
} catch (Exception e) {
throw new RuntimeException("输入日期有误");
}
}
}
在spring配置文件中配置类型转换器,spring配置类型转换器的机制是:将自定义的转换器注册到类型转换服务中去。
<!-- 配置类型转换器工厂 -->
<bean id="converterService" class="org.springframework.context.support.ConversionServiceFactoryBean">
<!-- 给工厂注入一个新的类型转换器 -->
<property name="converters">
<array>
<!-- 配置自定义类型转换器 -->
<bean class="com.joker.web.converter.StringToDateConverter"></bean>
</array>
</property>
</bean>
<!-- 引用自定义类型转换器 -->
<mvc:annotation-driven conversion-service="converterService"></mvc:annotation-driven>
5. 使用Servlet API对象作为方法参数
SpringMVC还支持使用原始Servlet API对象作为控制器方法的参数,使用方式很简单,直接在方法参数列表中添加相应的Servlet API对象即可,如下所示:
@Controller("account")
public class AccountController {
@RequestMapping("/testServletAPI")
public String testServletAPI(HttpServletRequest request, HttpServletResponse response, HttpSession session) {
System.out.println(request);
System.out.println(response);
System.out.println(session);
return "success";
}
}