SpringMVC专题(三)-SpringMVC 的请求参数绑定

1.绑定说明

1.1.绑定的机制

我们都知道,表单中请求参数都是基于 key=value 的。
SpringMVC 绑定请求参数的过程是通过把表单提交请求参数,作为控制器中方法参数进行绑定的。
例如:

<a href="account/findAccount?accountId=10">查询账户</a>

中请求参数是:

accountId=10

Controller实现:

/**
* 查询账户
* @return
*/
@RequestMapping("/findAccount")
public String findAccount(Integer accountId) {
   
   System.out.println("查询了账户。。。。"+accountId);
   return "success"; 
}
1.2.支持的数据类型
  • 基本类型参数:
    包括基本类型和 String 类型
  • POJO 类型参数:
    包括实体类,以及关联的实体类
  • 数组和集合类型参数:
    包括 List 结构和 Map 结构的集合(包括数组)
    SpringMVC 绑定请求参数是自动实现的,但是要想使用,必须遵循使用要求。
1.3.使用要求
  • 如果是基本类型或者 String 类型:
    要求我们的参数名称必须和控制器中方法的形参名称保持一致。(严格区分大小写)
  • 如果是 POJO 类型,或者它的关联对象:
    要求表单中参数名称和 POJO 类的属性名称保持一致。并且控制器方法的参数类型是 POJO 类型。
  • 如果是集合类型,有两种方式:
    第一种
    要求集合类型的请求参数必须在 POJO 中。在表单中请求参数名称要和 POJO 中集合属性名称相同。
    给 List 集合中的元素赋值,使用下标。
    给 Map 集合中的元素赋值,使用键值对。
    第二种
    接收的请求参数是 json 格式数据。需要借助一个注解实现。

注意: 它还可以实现一些数据类型自动转换。内置转换器全都在:
org.springframework.core.convert.support 包下。

有: java.lang.Boolean ->
java.lang.String : ObjectToStringConverter java.lang.Character ->
java.lang.Number : CharacterToNumberFactory java.lang.Character ->
java.lang.String : ObjectToStringConverter java.lang.Enum ->
java.lang.String : EnumToStringConverter java.lang.Number ->
java.lang.Character : NumberToCharacterConverter java.lang.Number ->
java.lang.Number : NumberToNumberConverterFactory java.lang.Number ->
java.lang.String : ObjectToStringConverter java.lang.String ->
java.lang.Boolean : StringToBooleanConverter java.lang.String ->
java.lang.Character : StringToCharacterConverter java.lang.String ->
java.lang.Enum : StringToEnumConverterFactory java.lang.String ->
java.lang.Number : StringToNumberConverterFactory java.lang.String ->
java.util.Locale : StringToLocaleConverter java.lang.String ->
java.util.Properties : StringToPropertiesConverter java.lang.String ->
java.util.UUID : StringToUUIDConverter java.util.Locale ->
java.lang.String : ObjectToStringConverter java.util.Properties ->
java.lang.String : PropertiesToStringConverter java.util.UUID ->
java.lang.String : ObjectToStringConverter …
如遇特殊类型转换要求,需要我们自己编写自定义类型转换器。

2.使用示例

2.1.基本类型和 String 类型作为参数
  • jsp 代码:
<!-- 基本类型示例 -->
<a href="account/findAccount?accountId=10&accountName=zhangsan">查询账户</a>
  • 控制器代码:
/**
* 查询账户
* @return
*/
@RequestMapping("/findAccount")
public String findAccount(Integer accountId,String accountName) {
   
   System.out.println("查询了账户。。。。"+accountId+","+accountName);
   return "success";
}
2.2.POJO 类型作为参数
  • 实体类代码:
/**
* 账户信息
* @Version 1.0
*/
public class Account implements Serializable {
   
	private Integer id;
	private String name;
	private Float money;
	private Address address;
	//getters and setters
}

/**
* 地址的实体类
* @Version 1.0
*/
public class Address implements Serializable {
   
	private String provinceName;
	private String cityName;
	//getters and setters
}
  • jsp 代码:
<!-- pojo 类型演示 --> 
<form action="account/saveAccount" method="post">
	账户名称:<input type="text" name="name" ><br/>
	账户金额:<input type="text" name="money" ><br/>
	账户省份:<input type="text" name="address.provinceName"
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

釣餌锒鐺

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值