JSON概述
JSON(JavaScript Object Notation,JS對(duì)象標(biāo)記)是一種輕量級(jí)的數(shù)據(jù)交換格式,最近幾年才流行起來(lái)。JSON是基于JavaScript的一個(gè)子集,使用了C、C++、C#、Java、 JavaScript、Per、 Python等其他語(yǔ)言的約定,采用完全獨(dú)立于編程語(yǔ)言的文本格式來(lái)存儲(chǔ)和表示數(shù)據(jù)。這些特性使JSON成為理想的數(shù)據(jù)交互語(yǔ)言,它易于閱讀和編寫,同時(shí)也易于機(jī)器解析和生成。
與XML一樣,JSON也是基于純文本的數(shù)據(jù)格式。初學(xué)者可以使用JSON傳輸一個(gè)簡(jiǎn)單的String、 Number、 Boolean,也可以傳輸一個(gè)數(shù)組或者一個(gè)復(fù)雜的 Object對(duì)象。
JSON有如下兩種數(shù)據(jù)結(jié)構(gòu)。
1.對(duì)象結(jié)構(gòu)
對(duì)象結(jié)構(gòu)以“{”開(kāi)始,以“}”結(jié)束。中間部分由0個(gè)或多個(gè)以英文“,”分隔的“key:value”對(duì)構(gòu)成,其中key和value之間也是英語(yǔ)“:”。
1
2
3
4
5
|
{ keyl: valuel, key2: value2, …… } |
2.數(shù)組結(jié)構(gòu)
數(shù)組結(jié)構(gòu)以“[”開(kāi)始,以“]”結(jié)束。中間部分由0個(gè)或多個(gè)以英文“,”分隔的值的列表組成。
1
2
3
4
5
|
[ valuel, value2, …… ] |
JSON數(shù)據(jù)轉(zhuǎn)換
為了實(shí)現(xiàn)瀏覽器與控制器類(Controller)之間的數(shù)據(jù)交互,Spring提供了一個(gè)HttpMessageConverter
Spring為 HttpMessageConverter
要使用MappingJacksona2HttpMessageConverter對(duì)數(shù)據(jù)進(jìn)行轉(zhuǎn)換,就需要使用 Jackson
的開(kāi)源包,開(kāi)發(fā)時(shí)所需的開(kāi)源包及其描述如下所示。
- jackson-annoations-2.8. 8. Jar:JSON轉(zhuǎn)換注解包。
- jackson-core-2.8. 8.jar:JSON轉(zhuǎn)換核心包。
- Jackson- databind-2.8.8.jar:JSON轉(zhuǎn)換的數(shù)據(jù)綁定包。
在使用注解式開(kāi)發(fā)時(shí),需要用到兩個(gè)重要的JSON格式轉(zhuǎn)換注解@RequestBody和@ ResponseBody,
springmvc-config. xml:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
<? xml version = "1.0" encoding = "UTF-8" ?> < beans xmlns = "http://www.springframework.org/schema/beans" xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc = "http://www.springframework.org/schema/mvc" xmlns:context = "http://www.springframework.org/schema/context" xmlns:tx = "http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd"> <!--指定需要掃描的包 --> < context:component-scan base-package = "com.ssm.controller" /> <!-- 配置注解驅(qū)動(dòng) --> < mvc:annotation-driven /> <!-- 配置靜態(tài)資源的訪問(wèn)映射,此配置中的文件,將不被前端控制器攔截 --> < mvc:resources location = "/js/" mapping = "/js/**" ></ mvc:resources > <!-- 定義視圖解析器 --> < bean id = "viewResoler" class = "org.springframework.web.servlet.view.InternalResourceViewResolver" > <!-- 設(shè)置前綴 --> < property name = "prefix" value = "/WEB-INF/jsp/" /> <!-- 設(shè)置后綴 --> < property name = "suffix" value = ".jsp" /> </ bean > </ beans > |
不僅配置了組件掃描器和視圖解析器,還配置了 Spring MVC的注解驅(qū)動(dòng)<mvc: annotation- driven/>和靜態(tài)資源訪問(wèn)映射mvc:resources…/。其中<mvc: annotation- driven/>配置會(huì)自動(dòng)注冊(cè) RequestMappingHandlerMapping和 RequestMappingHandlerAdapter兩個(gè)Bean,并提供對(duì)讀寫XML和讀寫JSON等功能的支持。mvc:resources…/元素用于配置靜態(tài)資源的訪問(wèn)路徑。由于在web.xml中配置的“/”會(huì)將頁(yè)面中引入的靜態(tài)文件也進(jìn)行攔截,而攔截后頁(yè)面中將找不到這些靜態(tài)資源文件,這樣就會(huì)引起頁(yè)面報(bào)錯(cuò)。而增加了靜態(tài)資源的訪問(wèn)映射配置后,程序會(huì)自動(dòng)地去配置路徑下找靜態(tài)的內(nèi)容。
json.jsp:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> < html > < head > < meta http-equiv = "Content-Type" content = "text/html; charset=UTF-8" > < title >測(cè)試JSON交互</ title > < script type = "text/javascript" src = "${pageContext.request.contextPath}/js/jquery-1.11.3.min.js" > </ script > < script type = "text/javascript" > function testJson(){ //獲取輸入的客戶信息 var loginname=$("#loginname").val(); var password=$("#password").val(); $.ajax({ url:"${pageContext.request.contextPath}/testJson", type:"post", //data表示發(fā)送的數(shù)據(jù) data:JSON.stringfy({loginname:loginname,password:password}), // 定義發(fā)送請(qǐng)求的數(shù)據(jù)格式為JSON字符串 contentType:"application/json;charset=UTF-8", //定義回調(diào)響應(yīng)的數(shù)據(jù)格式為JSON字符串,該屬性可以省略 dataType:"json", //成功響應(yīng)的結(jié)果 success:function(data){ if(data!=null){ alert("您輸入的登錄名為:"+data.loginname+"密碼為:"+data.password); } } }); } </ script > </ head > < body > < form > 登錄名:< input type = "text" name = "loginname" id = "loginname" /> < br /> 密碼:< input type = "password" name = "password" id = "password" /> < br /> < input type = "button" value = "測(cè)試JSON交互" onclick = "testJson()" /> </ form > </ body > </ html > |
在AJAX中包含了3個(gè)特別重要的屬性,其說(shuō)明如下。
- data:即請(qǐng)求時(shí)攜帶的數(shù)據(jù),當(dāng)使用JSON格式時(shí),要注意編寫規(guī)范。
- contentType:當(dāng)請(qǐng)求數(shù)據(jù)為JSON格式時(shí),值必須為 application/json。
- dataType:當(dāng)響應(yīng)數(shù)據(jù)為JSON時(shí),可以定義dataType屬性,并且值必須為json。其中
- dataType:"json"也可以省略不寫,頁(yè)面會(huì)自動(dòng)識(shí)別響應(yīng)的數(shù)據(jù)格式。
- 在上述測(cè)試頁(yè)面 json.jsp還需要引入jquery.js文件,本例中引入了 WebContent目錄下js文件夾中的jquery-1.11.3.min.js。
CustomerController.java:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
package com.ssm.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.ResponseBody; import com.ssm.po.Customer; @Controller public class CustomerController { /* * 接收頁(yè)面請(qǐng)求的JSON數(shù)據(jù),并返回JSON格式結(jié)果 */ @ResponseBody public Customer testJson( @RequestBody Customer customer){ //打印接收到的JSON格式數(shù)據(jù) System.out.println(customer); return customer; } } |
RESTful支持
RESTful也稱之為REST(Representational State Transfer),可以將它理解為一種軟件架構(gòu)風(fēng)格或設(shè)計(jì)風(fēng)格。
RESTful風(fēng)格就是把請(qǐng)求參數(shù)變成請(qǐng)求路徑的一種風(fēng)格。例如,傳統(tǒng)的URL請(qǐng)求格式為:
http://.../queryitems?id=1
而采用RESTful風(fēng)格后,其∪RL請(qǐng)求為:
http://.../items/1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
/* * 接收RESTful風(fēng)格的請(qǐng)求,其接收方式為GET */ @RequestMapping (value= "/customer/{id}" ,method=RequestMethod.GET) @ResponseBody public Customer selectCustomer( @PathVariable ( "id" ) Integer id){ //查看接收數(shù)據(jù) System.out.println(id); Customer customer= new Customer(); //模擬根據(jù)id查詢出客戶對(duì)象數(shù)據(jù) if (id== 10 ){ customer.setLoginname( "wujit" ); } //返回JSON格式的數(shù)據(jù) return customer; } |
@RequestMapping(vaue="customer/{id}", method= RequestMethod.GET)注解用于匹配請(qǐng)求路徑(包括參數(shù))和方式。其中vaue="/user/{id}"表示可以匹配以“/user/{id}”結(jié)尾的請(qǐng)求,id為請(qǐng)求中的動(dòng)態(tài)參數(shù);method= RequestMethod.GET表示只接收GET方式的請(qǐng)求。方法中的@ PathVariable("id")注解則用于接收并綁定請(qǐng)求參數(shù),它可以將請(qǐng)求URL中的變量映射到方法的形參上,如果請(qǐng)求路徑為“/user/{id}”,即請(qǐng)求參數(shù)中的id和方法形參名稱id一樣,則@PathVariable后面的“("id")”可以省略。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://www.cnblogs.com/zq98/p/13195134.html