(五)SpringMVC 参数绑定

(五)SpringMVC 参数绑定

 

1 、默认支持的参数类型

默认支持的参数类型,就是可以直接写在 @RequestMapping 所注解的方法中的参数类型,一共有四类:

  • HttpServletRequest
  • HttpServletResponse
  • HttpSession
  • Model/ModelMap

在请求的方法中,默认的参数就是这几个,如果在方法中,刚好需要这几个参数,那么就可以把这几个参数加入到方法中。

2、简单数据类型

String、Integer、Boolean、Double 等等简单数据类型也都是支持的。

    @RequestMapping(value = "/doAdd",method = RequestMethod.POST) 
    @ResponseBody 
    public void doAdd(String name, String author, Double price, Boolean ispublic) { 
        System.out.println(name); 
        System.out.println(author); 
        System.out.println(price); 
        System.out.println(ispublic); 
    } 
} 

注意,由于 doAdd 方法确实不想返回任何值,所以需要给该方法添加 @ResponseBody 注解,表示这个方法到此为止,不用再去查找相关视图了。另外, POST 请求传上来的中文会乱码,所以,我们在 web.xml 中再额外添加一个编码过滤器:

<filter> 
    <filter-name>encoding</filter-name> 
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> 
    <init-param> 
        <param-name>encoding</param-name> 
        <param-value>UTF-8</param-value> 
    </init-param> 
    <init-param> 
        <param-name>forceRequestEncoding</param-name> 
        <param-value>true</param-value> 
    </init-param> 
    <init-param> 
        <param-name>forceResponseEncoding</param-name> 
        <param-value>true</param-value> 
    </init-param> 
</filter>
<filter-mapping> 
    <filter-name>encoding</filter-name> 
    <url-pattern>/*</url-pattern> 
</filter-mapping> 

在上面的绑定中,有一个要求,表单中字段的 name 属性要和接口中的变量名一一对应,才能映射成功,否则服务端接收不到前端传来的数据。有一些特殊情况,我们的服务端的接口变量名可能和前端不一致,这个时候我们可以通过

@RequestParam 注解来解决。

这个注解的的功能主要有三方面:

1. 给变量取别名

2. 设置变量是否必填

3. 给变量设置默认值

@RequestMapping(value = "/doAdd",method = RequestMethod.POST) 
@ResponseBody 
public void doAdd(@RequestParam(value = "name", required = true, defaultValue = "三国演义") String bookname, 
String author, Double price, Boolean ispublic) { System.out.println(bookname); System.out.println(author); System.out.println(price); System.out.println(ispublic); }

     required 属性默认为 true,即只要添加了 @RequestParam 注解,这个参数默认就是必填的,如果不填,请求无法提交,会报 400 错误,如果这个参数不是必填项,可以手动把 required 属性设置为 false。但是,如果同时设置了defaultValue,这个时候,前端不传该参数到后端,即使 required 属性为true,它也不会报错。

3、实体类

参数除了是简单数据类型之外,也可以是实体类。实际上,在开发中,大部分情况下,都是实体类。

@RequestMapping(value = "/doAdd",method = RequestMethod.POST) 
@ResponseBody 
public void doAdd(Book book) { 
    System.out.println(book); 
} 

 

4、自定义参数绑定

    前面的转换,都是系统自动转换的,这种转换仅限于基本数据类型。特殊的数据类型,系统无法自动转换,例如日期。例如前端传一个日期到后端,后端不是用字符串接收,而是使用一个 Date 对象接收,这个时候就会出现参数类型转换失败。这个时候,需要我们手动定义参数类型转换器,将日期字符串手动转为一个 Date 对象。

@Component 
public class DateConverter implements Converter<String, Date> { 
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); 
    public Date convert(String source) { 
        try { 
            return sdf.parse(source); 
        } catch (ParseException e) { 
            e.printStackTrace(); 
        } 
        return null; 
    } 
} 

接下来,在 SpringMVC 的配置文件中,配置该 Bean,使之生效。

<mvc:annotation-driven conversion-service="conversionService"/> 
<bean class="org.springframework.format.support.FormattingConversionServiceFactoryBean" id="conversionService"> 
    <property name="converters"> 
        <set> 
            <ref bean="dateConverter"/> 
        </set> 
    </property> 
</bean> 

配置完成后,在服务端就可以接收前端传来的日期参数了。

 

5、集合类的参数

String 数组可以直接用数组去接收

@RequestMapping(value = "/doAdd",method = RequestMethod.POST) 
@ResponseBody 
public void doAdd(Book book, String[] favorites) { 
    System.out.println(Arrays.toString(favorites)); 
    System.out.println(book); 
} 

注意:  前端传来的数组对象,服务端不可以使用 List 集合去接收。如果需要使用 List 集合接收前端传来的数据,List 集合本身需要放在一个封装对象中,这个时候,List 中,可以是基本数据类型,也可以是对象。

 

6、Map

相对于实体类而言,Map 是一种比较灵活的方案,但是,Map 可维护性比较差,因此一般不推荐使用。

 

posted @ 2021-02-07 00:03  邓维-java  阅读(244)  评论(0)    收藏  举报