在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); }