很简单的一个东西,这里就不做过多介绍了,写一个小Demo,随手记录下。
首先,在搭好SpringMVC工程环境之后,如果想用Spring自带的Json,需要额外的添加2个JAR包:
1、jackson-core-asl-1.9.9.jar
2、jackson-mapper-asl-1.9.9.jar
我这里使用的是Maven,也相对应的给出pox.xml
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-core-lgpl</artifactId>
<version>1.8.1</version>
</dependency> <dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-lgpl</artifactId>
<version>1.8.1</version>
</dependency>
当然也可以不使用Spring自带的Json,还有很多第三方的Json支持包,比如谷歌的Gson,都是很好用的东西。
关于Gson的使用,之前的文章里也有做介绍,请戳:《Gson简要使用笔记》http://www.cnblogs.com/lichenwei/p/3987429.html
好了,进入正题,要使用Spring自带的Json,需要在SpringMVC配置文件里做一些配置:
<!-- 处理在类级别上的@RequestMapping注解 -->
<bean
class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" />
<!-- 处理在方法级别上的@RequestMapping注解 -->
<bean
class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
<property name="messageConverters">
<list>
<bean
class="org.springframework.http.converter.StringHttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<!-- 默认是ISO-88859-1,避免乱码这里设置为UTF-8 -->
<value>
text/html;charset=UTF-8
</value>
</list>
</property>
</bean>
<!-- 启动JSON格式的配置 -->
<bean id="jacksonMessageConverter"
class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
<!-- 解决 HttpMediaTypeNotAcceptableException: Could not find acceptable
representation -->
<property name="supportedMediaTypes">
<list>
<value>application/json;charset=UTF-8</value>
</list>
</property>
</bean>
</list>
</property>
</bean>
有了以上的配置之后,我们只需要在对应处理AJAX请求的方法上加上注解@ResponseBody,这样Spring就会帮我们把内容或对象作为HTTP响应的正文返回,会跳过视图处理部分,而调用适合HttpMessageConverter,将返回值(对象、字符串、List集合等)写入输出流。
SpringMVC的用法这里就不再多说了,直接给出关键代码:
//向页面直接输出Json字符串
@ResponseBody
@RequestMapping(value="/showUser",params="json",produces="application/json")
public User showUserJson(){
User user=userService.getUserById(1);//获取数据库的一条信息
return user;
}
@RequestMapping
value: 指定请求的实际地址,指定的地址可以是URI Template 模式(后面将会说明);
produces: 指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回;
params: 指定request中必须包含某些参数值,才让该方法处理。
看一下页面输出:
怎么样?相比Struts2输出Json要简单的多吧,少去了很多配置和通配符的设定。
再来看一下和AJAX的配合使用,服务端的代码依旧如上,然后我们写一个JSP页面进行测试
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>
<html>
<head>
<script type="text/javascript" src="<%=basePath %>js/jquery-1.4.4.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$("#send").click(function(){
$.ajax({
type:"get",
url:"<%=basePath %>userController/showUser?json",
dataType:" json",
success:function(data){
alert(data);
}
});
});
});
</script>
</head>
<body>
<h3>点击下面按钮,输出Json信息</h3>
<input type="button" id="send" name="send" value="获取json信息">
</body>
</html>
这里要提到一个注意事项,我们在整合SpringMVC的时候需要在web.xml进行对DispatcherServlet的配置
<!-- SpringMVC配置 -->
<servlet>
<servlet-name>springDispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet> <servlet-mapping>
<servlet-name>springDispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
如果你配置DispatcherServlet拦截*.do就不会存在静态资源访问的问题,
但如果你和我一样配置DispatcherServlet拦截 / (所有),那么对*.js,*.css,*.jpg等资源的访问也就被拦截了,也就访问不到了。
这里顺带说下解决方法:
激活Tomcat的defaultServlet来处理静态文件
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.jpg</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.js</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.css</url-pattern>
</servlet-mapping>
每种文件类型都要配置,要写在DispatcherServlet的前面, 让defaultServlet先拦截,这个就不会进入Spring了。
看下实现效果: