在web項目中使用Json進行數據的傳輸是非常常見且有用的,在這里介紹下在SpringMVC中使用Json傳數據的一種方法,在我的使用中,主要包括下面四個部分(我個人喜好使用maven這類型工具進行項目構建):
<dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.7.5</version> </dependency> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-core-asl</artifactId> <version>1.9.13</version> </dependency> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.13</version> </dependency>
<mvc:annotation-driven /> <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>text/html;charset=UTF-8</value> </list> </property> </bean>
<script type="text/javascript">
function getInfo() {
$.ajax({
type: "POST",
dataType: "json",
url: "/ajax/getHtml",
success: function(map) {
$("input[name=getInfo]").after("<table>");
$.each(map, function(i, item) {
$("input[name=getInfo]").after(
"<tr><td>" + item.userName + "</td>" +
"<td>" + item.password + "</td></tr>");
});
$("input[name=getInfo]").after("</table");
},
error: function(ret) {
alert("加載失敗");
}
});
}
</script>
@ResponseBody //返回不是html之外的數據必須要有這個注解 @RequestMapping(value="/getHtml") public ModelAndView getHtml() { Map<String, User> map = new HashMap<String, User>(); User li=new User(); li.setUserName("Li"); li.setPassword("123"); User na=new User(); na.setUserName("Na"); na.setPassword("456"); map.put("1", li); map.put("2",na); return new ModelAndView(new MappingJackson2JsonView(),map); }
