欢迎支持笔者新作:《深入理解Kafka:核心设计与实践原理》和《RabbitMQ实战指南》,同时欢迎关注笔者的微信公众号:朱小厮的博客。
欢迎跳转到本文的原文链接:https://honeypps.com/java/spring-mvc-annotation-responsebody/
博主习惯性用SpringMVC的@ResponseBody注解返回JSON字符串,原先采用的方法是GSON将对象转换成json字符串。(需要引入gson-2.x.x.jar的jar包)
- @ResponseBody
- @RequestMapping(value = "/cpuUsage.do", produces = "text/html;charset=UTF-8")
- public String getCpuUsage(@RequestParam(value = "name", required = true) String clusterName)
- {
- logger.info("/charts/cluster/cpuUsage.do?name=" + clusterName);
- String ans = null;
- try
- {
- ans = clusterChartsService.getCpuUsage(clusterName);
- logger.info(ans);
- }
- catch (InstantiationException | IllegalAccessException | RuntimeFaultFaultMsg | DatatypeConfigurationException
- | NullPointerException | ConnectException | XMLStreamException e)
- {
- logger.error(e.getMessage());
- }
- return ans;
- }
如上代码所示,Controller的返回值就为String类型。
在getCpuUsage()方法中:
- public String getCpuUsage(String clusterName) throws RuntimeFaultFaultMsg, DatatypeConfigurationException,
- InstantiationException, IllegalAccessException, ConnectException, XMLStreamException
- {
- double value = MoniterWsInterface.getClusterCpuUsageByClusterName(clusterName);
- Charts charts = new Charts(value, new Date());
- String ans = Gson.class.newInstance().toJson(charts);
-
- return ans;
- }
采用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的配置文件中加入:
- <bean
- class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
- <property name="messageConverters">
- <ref bean="mappingJacksonHttpMessageConverter" />
- </property>
- </bean>
- <bean id="mappingJacksonHttpMessageConverter"
- class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
- <property name="supportedMediaTypes">
- <list>
- <value>text/html;charset=UTF-8</value>
- </list>
- </property>
- </bean>
这样就可以采用@ResponseBody注解自动将对象(包括普通对象,List对象,Map对象等)转换为JSON.
- @RequestMapping("/test.do")
- @ResponseBody
- public List<String> test(){
- List<String> list = new ArrayList<String>();
- list.add("zzh1");
- list.add("zzh1");
- list.add("zzh2");
- list.add("字符串");
- return list;
- }
如上代码可以看到直接返回一个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实战指南》,同时欢迎关注笔者的微信公众号:朱小厮的博客。