关键词搜索

源码搜索 ×
×

SpringMVC中@ResponseBody的相关注意点

发布2015-12-09浏览10869次

详情内容

欢迎支持笔者新作:《深入理解Kafka:核心设计与实践原理》和《RabbitMQ实战指南》,同时欢迎关注笔者的微信公众号:朱小厮的博客。

欢迎跳转到本文的原文链接:https://honeypps.com/java/spring-mvc-annotation-responsebody/

 

博主习惯性用SpringMVC的@ResponseBody注解返回JSON字符串,原先采用的方法是GSON将对象转换成json字符串。(需要引入gson-2.x.x.jar的jar包)

 

  1. @ResponseBody
  2. @RequestMapping(value = "/cpuUsage.do", produces = "text/html;charset=UTF-8")
  3. public String getCpuUsage(@RequestParam(value = "name", required = true) String clusterName)
  4. {
  5. logger.info("/charts/cluster/cpuUsage.do?name=" + clusterName);
  6. String ans = null;
  7. try
  8. {
  9. ans = clusterChartsService.getCpuUsage(clusterName);
  10. logger.info(ans);
  11. }
  12. catch (InstantiationException | IllegalAccessException | RuntimeFaultFaultMsg | DatatypeConfigurationException
  13. | NullPointerException | ConnectException | XMLStreamException e)
  14. {
  15. logger.error(e.getMessage());
  16. }
  17. return ans;
  18. }

如上代码所示,Controller的返回值就为String类型。
在getCpuUsage()方法中:

 

 

  1. public String getCpuUsage(String clusterName) throws RuntimeFaultFaultMsg, DatatypeConfigurationException,
  2. InstantiationException, IllegalAccessException, ConnectException, XMLStreamException
  3. {
  4. double value = MoniterWsInterface.getClusterCpuUsageByClusterName(clusterName);
  5. Charts charts = new Charts(value, new Date());
  6. String ans = Gson.class.newInstance().toJson(charts);
  7. return ans;
  8. }

采用Gson将对象转换成JSON字符串,然后返回给前端调用。

 

但是有些读者可能了解到Spring的@ResponseBody可以自动将对象转换为JSON对象然后返回给前端,这里项目中需要加入两个jar包:jackson-core-asl-1.9.x.jar和jackson-mapper-asl-1.9.x.jar。然后在springMVC的配置文件中加入:

 

<mvc:annotation-driven />

 

这句即可,也可以显示的标注,即在springMVC的配置文件中加入:

 

  1. <bean
  2. class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
  3. <property name="messageConverters">
  4. <ref bean="mappingJacksonHttpMessageConverter" />
  5. </property>
  6. </bean>
  7. <bean id="mappingJacksonHttpMessageConverter"
  8. class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
  9. <property name="supportedMediaTypes">
  10. <list>
  11. <value>text/html;charset=UTF-8</value>
  12. </list>
  13. </property>
  14. </bean>

这样就可以采用@ResponseBody注解自动将对象(包括普通对象,List对象,Map对象等)转换为JSON.

 

 

  1. @RequestMapping("/test.do")
  2. @ResponseBody
  3. public List<String> test(){
  4. List<String> list = new ArrayList<String>();
  5. list.add("zzh1");
  6. list.add("zzh1");
  7. list.add("zzh2");
  8. list.add("字符串");
  9. return list;
  10. }

如上代码可以看到直接返回一个List的对象,这里springMVC的@ResponseBody标签会自动采用jackson讲对象转换为JSON。

 

这里有个小坑。在@ResponseBody注解上面还有一个@RequestMapping注解,有时候需要显示的标注一些信息,如:

 

@RequestMapping(value = "/test.do", produces = "application/json;charset=UTF-8")

如果这里的produces=“text/html,charset=UTF-8”就会报错:HTTP406的错误。所以这里要特别的小心。

 

好了@ResponseBody的相关知识先说到这里,以后继续补充。

 

欢迎跳转到本文的原文链接:https://honeypps.com/java/spring-mvc-annotation-responsebody/

 

欢迎支持笔者新作:《深入理解Kafka:核心设计与实践原理》和《RabbitMQ实战指南》,同时欢迎关注笔者的微信公众号:朱小厮的博客。

相关技术文章

最新源码

下载排行榜

点击QQ咨询
开通会员
返回顶部
×
微信扫码支付
微信扫码支付
确定支付下载
请使用微信描二维码支付
×

提示信息

×

选择支付方式

  • 微信支付
  • 支付宝付款
确定支付下载