SpringMVC中@ResponseBody的相关注意点

欢迎支持笔者新作:《深入理解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实战指南》,同时欢迎关注笔者的微信公众号:朱小厮的博客。

已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页