Spring的注解非常多,这篇文章我们说一下它的@RequestBody 和 @ResponseBody注解。
@ResponseBody
简单说,@ResponseBody注解将HttpRequest的请求体映射为Java的POJO对象。一般Get方法是没有body的,在post数据的时候可以指定json数据。
一般用法如下:
@RestController
public class FirstController {
private final Logger logger = LoggerFactory.getLogger(getClass());
@RequestMapping("/requestbody")
public String requestbody(
@RequestBody User user
){
return user.toString();
}
}
注意:对于想要转换的格式,记得要添加对应的依赖包。比如json的,添加Gson。或者jackson,必要时还要配置一下converter的bean。
- 不添加@RequestBody注解的结果
-
添加@RequestBody注解的结果
可以看到@RequestBody注解主要用来处理请求中body的部分。
@ResponseBody
这个注解可以放在方法上用来指示这个方法,返回的值直接写到Http的响应体中,不需要替换为Spring的Model或者解析为视图。
如下面的这个例子,方法直接返回"index"字符串。
@RequestMapping({"/","/index"})
@ResponseBody
public String index(){
return "index";
}
和@RequestBody一样,@ResponseBody也是由HttpMessageConverter进行对象之间的转换的。如果要自己配置,那么在Spring的配置文件中,做如下配置。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<mvc:annotation-driven />
<context:component-scan base-package="me.aihe" />
<!-- HttpMessageConverter的配置 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">
<property name="messageConverters">
<list>
<ref bean="stringHttpMessageConverter"></ref>
<ref bean="gsonHttpMessageConverter"></ref>
</list>
</property>
</bean>
<bean id="stringHttpMessageConverter" class="org.springframework.http.converter.StringHttpMessageConverter" />
<bean id="gsonHttpMessageConverter" class="org.springframework.http.converter.json.GsonHttpMessageConverter" />
</beans>
最后
关于这两个注解的使用,可以自行尝试下,环境搭建参考我的上篇文章