標籤: springmvcjavascript
[TOC]html
本文主要介紹如何在springmvc中進行json數據的交互,先是環境準備和配置,而後分別展現了「輸入json串,輸出是json串」和「輸入key/value,輸出是json串」兩種狀況下的交互前端
json數據格式在接口調用中、html頁面中較經常使用,json格式比較簡單,解析還比較方便。java
好比:webservice接口,傳輸json數據.jquery
最開始我少了jackson-databind
依賴,程序各類報錯。git
<!-- json 轉換--> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.7.2</version> </dependency> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.13</version> </dependency>
查看依賴樹github
[INFO] +- com.fasterxml.jackson.core:jackson-databind:jar:2.7.2:compile [INFO] | +- com.fasterxml.jackson.core:jackson-annotations:jar:2.7.0:compile [INFO] | \- com.fasterxml.jackson.core:jackson-core:jar:2.7.2:compile [INFO] \- org.codehaus.jackson:jackson-mapper-asl:jar:1.9.13:compile [INFO] \- org.codehaus.jackson:jackson-core-asl:jar:1.9.13:compile
在註解適配器中加入messageConverters
web
<!--註解適配器 --> <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 />
則不用定義上邊的內容。ajax
顯示兩個按鈕分別測試spring
<%-- Created by IntelliJ IDEA. User: brian Date: 2016/3/7 Time: 20:49 To change this template use File | Settings | File Templates. --%> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>json交互測試</title> <script type="text/javascript" src="${pageContext.request.contextPath }/js/jquery-1.4.4.min.js"></script> <script type="text/javascript"> //請求json,輸出是json function requestJson(){ 省略 } //請求key/value,輸出是json function responseJson(){ 省略 } </script> </head> <body> <input type="button" onclick="requestJson()" value="請求json,輸出是json"/> <input type="button" onclick="responseJson()" value="請求key/value,輸出是json"/> </body>
@Controller public class JsonTest { 省略 }
使用jquery的ajax提交json串,對輸出的json結果進行解析。
//請求json,輸出是json function requestJson(){ $.ajax({ type:'post', url:'${pageContext.request.contextPath }/requestJson.action', contentType:'application/json;charset=utf-8', //數據格式是json串,商品信息 data:'{"name":"手機","price":999}', success:function(data){//返回json結果 alert(data); } }); }
//請求json串(商品信息),輸出json(商品信息) //@RequestBody將請求的商品信息的json串轉成itemsCustom對象 //@ResponseBody將itemsCustom轉成json輸出 @RequestMapping("/requestJson") public @ResponseBody ItemsCustom requestJson(@RequestBody ItemsCustom itemsCustom){ //@ResponseBody將itemsCustom轉成json輸出 return itemsCustom; }
能夠看到,request和response的HTTP頭的Content-Type都是application/json;charset=utf-8
使用jquery的ajax提交key/value串,對輸出的json結果進行解析
//請求key/value,輸出是json function responseJson(){ $.ajax({ type:'post', url:'${pageContext.request.contextPath }/responseJson.action', //請求是key/value這裏不須要指定contentType,由於默認就 是key/value類型 //contentType:'application/json;charset=utf-8', //數據格式是json串,商品信息 data:'name=手機&price=999', success:function(data){//返回json結果 alert(data.name); } }); }
//請求key/value,輸出json @RequestMapping("/responseJson") public @ResponseBody ItemsCustom responseJson(ItemsCustom itemsCustom){ //@ResponseBody將itemsCustom轉成json輸出 return itemsCustom; }
能夠看到,key/value鍵值對的默認Content-Type是application/x-www-form-urlencoded
,同時,咱們收到了響應「手機」