SpringMVC返回json数据的三种方式
作者:bea
Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。使用 Spring 可插入的 MVC架构,从而在使用Spring进行WEB开发时,可以选择使用Spring的SpringMVC框架或集成其他MVC开发框架,如Struts1,Struts2等。
1、第一种方式是spring2时代的产物,也就是每个json视图controller配置一个Jsoniew。
如:<bean id="defaultJsonView" class="org.springframework.web.servlet.view.json.MappingJacksonJsonView"/>
或者<bean id="defaultJsonView" class="org.springframework.web.servlet.view.json.MappingJackson2JsonView"/>
同样要用jackson的jar包。
2、第二种使用JSON工具将对象序列化成json,常用工具Jackson,fastjson,gson。
利用HttpServletResponse,然后获取response.getOutputStream()或response.getWriter()
直接输出。
示例:
public class JsonUtil
{
private static Gson gson=new Gson();
/**
* @MethodName : toJson
* @Description : 将对象转为JSON串,此方法能够满足大部分需求
* @param src
* :将要被转化的对象
* @return :转化后的JSON串
*/
public static String toJson(Object src) {
if (src == null) {
return gson.toJson(JsonNull.INSTANCE);
}
return gson.toJson(src);
}
}
3、第三种利用spring mvc3的注解@ResponseBody
例如:
@ResponseBody
@RequestMapping("/list")
public List<String> list(ModelMap modelMap) {
String hql = "select c from Clothing c ";
Page<Clothing> page = new Page<Clothing>();
page.setPageSize(6);
page = clothingServiceImpl.queryForPageByHql(page, hql);
return page.getResult();
}
然后使用spring mvc的默认配置就可以返回json了,不过需要jackson的jar包哦。
注意:当springMVC-servlet.xml中使用<mvc:annotation-driven />时,如果是3.1之前已经默认注入AnnotationMethodHandlerAdapter,3.1之后默认注入RequestMappingHandlerAdapter只需加上上面提及的jar包即可!
如果是手动注入RequestMappingHandlerAdapter 可以这样设置
配置如下:
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"
p:ignoreDefaultModelOnRedirect="true" >
<property name="messageConverters">
<list>
<bean class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"/>
</list>
</property>
</bean>
添加包
jackson-mapper-asl-*.jar
jackson-core-asl-*.jar
可以看出,使用方式越来越简单,程序员越来越傻,不知道是好事,还是坏事……
以上内容是小编给大家分享的SpringMVC返回json数据的三种方式,希望大家喜欢。
猜你喜欢
您可能感兴趣的文章:
- jQuery Validate初步体验(一)
- jQuery Uploadify 上传插件出现Http Error 302 错误的解决办法
- jQuery同步提交示例代码
- JavaScript匿名函数之模仿块级作用域
- 自定义Angular指令与jQuery实现的Bootstrap风格数据双向绑定的单选与多选下拉框
- jQuery入门之层次选择器实例简析
- jQuery使用$.ajax提交表单完整实例
- jQuery使用$.ajax进行即时验证实例详解
- JavaScript基础篇(6)之函数表达式闭包
- jQuery弹簧插件编写基础之“又见弹窗”
- jQuery点击改变class并toggle及toggleClass()方法定义用法
- Express实现前端后端通信上传图片之存储数据库(mysql)傻瓜式教程(二)
- Express的路由详解
- 在 Express 中使用模板引擎
- Express实现前端后端通信上传图片之存储数据库(mysql)傻瓜式教程(一)
- 基于jQuery实现复选框是否选中进行答题提示
- 详解AngularJS中module模块的导入导出
- SpringMVC restful 注解之@RequestBody进行json与object转换
- Spring mvc 接收json对象