@RequestParam
@requestParam接收的参数是来自requestHeader中,即请求头。RequestParam可以接受简单类型的属性,也可以接受对象类型,可设置可不设置,有三个属性
value: 请求中传入参数的名称,如果不设置后台接口的value值,则会默认为该变量名
required: 该参数是否为必传项。默认是true,表示请求中一定要传入对应的参数,否则会报404错误,如果设置为false时,当请求中没有此参数,将会默认为null,而对于基本数据类型的变量,则必须有值,这时会抛出空指针异常。如果允许空值,则接口中变量需要使用包装类来声明。
defaultValue: 参数的默认值,如果设置了该值,required=true将失效,自动为false,如果没有传该参数,就使用默认值,值可以使用SpEL表达式,如"#{systemProperties[‘java.vm.version’]}"
@RequestBody
注解@RequestBody接收的参数是来自requestBody中,即请求体。一般用于处理非 Content-Type: application/x-www-form-urlencoded编码格式的数据,比如:application/json、application/xml等类型的数据。
就application/json类型的数据而言,使用注解@RequestBody可以将body里面所有的json数据传到后端,后端再进行解析。GET请求中,因为没有HttpEntity,所以@RequestBody并不适用。
POST请求中,通过HttpEntity传递的参数,必须要在请求头中声明数据的类型Content-Type,SpringMVC通过使用
HandlerAdapter 配置的HttpMessageConverters来解析HttpEntity中的数据,然后绑定到相应的bean上。
最后:@RequestBody
可以和@RequestParam
同时使用,但一个方法里,@RequestBody
只能有一个,@RequestParam
可以有多个。