SpringMVC教程之json交互使用

时间:2025-09-25 04:30:10 java语言

SpringMVC教程之json交互使用

  Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。本文是百分网小编搜索整理的关于SpringMVC教程之json交互使用详解,供参考学习,希望对大家有所帮助!想了解更多相关信息请持续关注我们应届毕业生考试网!

  json数据交互

  1.1 @RequestBody

  作用:@RequestBody注解用于读取http请求的内容(字符串),通过springmvc提供的HttpMessageConverter接口将读到的内容转换为json、xml等格式的数据并绑定到controller方法的参数上。

  本例子应用:@RequestBody注解实现接收http请求的json数据,将json数据转换为Java对象

  1.2 @ResponseBody

  作用:该注解用于将Controller的方法返回的对象,通过HttpMessageConverter接口转换为指定格式的数据如:json,xml等,通过Response响应给客户端

  本例子应用:@ResponseBody注解实现将controller方法返回对象转换为json响应给客户端

  1.3 请求json,响应json实现:

  1.3.1 环境准备

  Springmvc默认用MappingJacksonHttpMessageConverter对json数据进行转换,需要加入jackson的包,如下:

  1.3.2 配置json转换器

  在注解适配器中加入messageConverters

  <!--注解适配器 -->

  <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">

  <property name="messageConverters">

  <list>

  <bean class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"></bean>

  </list>

  </property>

  </bean>

  注意:如果使用<mvc:annotation-driven /> 则不用定义上边的内容。

  1.3.3 controller编写

  /pic/p>

  @RequestMapping("/editItemSubmit_RequestJson")

  public @ResponseBody Items editItemSubmit_RequestJson(@RequestBody Items items) throws Exception {

  System.out.println(items);

  /pic/p>

  return items;

  }

  1.3.4 页面js方法编写:

  引入 js:

  <script type="text/JavaScript"

  src="${pageContext.request.contextPath }/js/jQuery-1.4.4.min.js"></script>

  /pic/p>

  function request_json(){

  $.ajax({

  type:"post",

  url:"${pageContext.request.contextPath }/item/editItemSubmit_RequestJson.action",

  contentType:"application/json;charset=utf-8",

  data:'{"name":"测试商品","price":99.9}',

  success:function(data){

  alert(data);

  }

  });

  }

  1.4 Form提交,响应json实现:

  采用form提交是最常用的作法,通常有post和get两种方法,响应json数据是为了方便客户端处理,实现如下:

  1.4.1 环境准备

  同第一个例子

  1.4.2 controller编写

  /pic/p>

  @RequestMapping("/editItemSubmit_ResponseJson")

  public @ResponseBody Items editItemSubmit_ResponseJson(Items items) throws Exception {

  System.out.println(items);

  /pic/p>

  return items;

  }

  1.4.3 页面js方法编写:

  function formsubmit(){

  var user = " name=测试商品&price=99.9";

  alert(user);

  $.ajax(

  {

  type:'post',/pic/p>

  url:'${pageContext.request.contextPath}/item/ editItemSubmit_RequestJson.action',

  /pic/x-www-form-urlencoded

  data:user,

  success:function(data){

  alert(data.name);

  }

  }

  )

  }

  从上边的js代码看出,已去掉ContentType的定义,ContentType默认为:application/x-www-form-urlencoded格式。

  1.4.4 jquery的form插件插件

  针对上边第二种方法,可以使用jquery的form插件提交form表单,实现ajax提交form表单,如下:

  引用js:

  <script type="text/javascript"

  src="${pageContext.request.contextPath }/js/jquery-1.4.4.min.js"></script>

  <script type="text/javascript"

  src="${pageContext.request.contextPath }/js/jquery.form.min.js"></script>

  js方法如下:

  function response_json() {

  /pic/p>

  var formObj = $("#itemForm");

  /pic/p>

  formObj.ajaxSubmit({

  dataType : "json",/pic/p>

  success : function(responseText) {

  alert(responseText);

  }

  });

  }

  1.4.5 小结

  实际开发中常用第二种方法,请求key/value数据,响应json结果,方便客户端对结果进行解析。

【SpringMVC教程之json交互使用】相关文章:

如何使用Jackson解析JSON示例01-31

在PHP语言中使用JSON12-11

php使用curl发送json格式数据实例11-25

php中序列化和json使用方法02-21

PS基础教程之:笔刷的简单使用02-08

java中的JSON操作09-13

PHP中Json应用03-01

javascript解析json实例07-24

springmvc如何设置多视图器呢02-21