激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|JavaScript|易語言|

服務器之家 - 編程語言 - JAVA教程 - spring接口通過配置支持返回多種格式(xml,json,html,excel)

spring接口通過配置支持返回多種格式(xml,json,html,excel)

2021-03-07 12:15Jekyll JAVA教程

這篇文章主要給大家介紹了關于spring接口如何通過配置支持返回多種格式(xml,json,html,excel)的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。

1. 簡介

本文主要給大家介紹使用SpringMVC的后端服務如何通過配置來支持多種返回值類型(xml,json,html,excel)

這里的代碼使用的是springboot,下載地址:https://github.com/xiagn825/springboot-todolist/tree/springboot-ContentNegotiation

2. 基礎概念

2.1 HttpHeader中Content-Type和Accept設置的區別

Accept:接口要返回給客戶端的數據格式

?
1
curl --header 'Accept:application/json' http://localhost:8080/todo

Content-Type:客戶端發送給服務器端的數據格式

?
1
curl -X PUT --header 'Content-Type:application/json' -d '{"title":"周末日程","content":"睡覺"}' http://localhost:8080/todo

2.2 SpringMVC生成輸出的兩種方式

1) 當服務端使用Restful的方式,只為客戶端的ajax或其他服務端請求提供數據時,通常會使用@ResponseBody來標識你的返回,這時候Spring使用HttpMessageConverter來把返回的對象格式化成所需的格式。

2) 當你需要提供表現層(比如:HTML),這時候SpringMVC使用ViewResolver來將處理你的返回。

有時候你的應用程序這兩者都要提供

2.3 SpringMVC輸出格式判定

很多時候為了支持多個系統或多個終端,你需要讓相同的數據已不同的表現形式輸出。

SpringMVC使用ContentNegotationStrategy來判定用戶請求希望得到什么格式的數據。

ContentNegotationStrategy通過三種方式來識別用戶想要返回什么樣的數據

  • 通過請求URL后綴:http://myserver/myapp/accounts/list.html 返回html格式
  • 通過請求的參數:http://myserver/myapp/accounts/list?format=xls 該設置默認不開啟,默認key是format。
  • 通過HTTP Header的Accept:Accept:application/xml 優先級由上至下

請看如下配置

?
1
2
3
4
5
6
7
8
9
10
@Override
public void configureContentNegotiation(ContentNegotiationConfigurer configurer) {
 configurer.favorPathExtension(false)
   .favorParameter(true)
   .parameterName("mediaType")
   .defaultContentType(MediaType.APPLICATION_JSON)
   .mediaType("xml", MediaType.APPLICATION_XML)
   .mediaType("html", MediaType.TEXT_HTML)
   .mediaType("json", MediaType.APPLICATION_JSON);
}

在你工程的WebMvcConfig中加入以上配置,表示關閉URL后綴的規則,打開請求參數規則并設置請求參數為'mediaType',默認的返回格式是json,還支持返回xml,html。

這三個組件是用來處理返回不同格式輸出的關鍵

  • Request Mappings: 決定不同的請求到不同的方法并返回不同的格式.
  • View Resolution: 根據類型返回合適的表示層.
  • HttpMessageConverters: 將request中的參數轉換成java對象,將java對象轉換成相應的輸出格式到response.

2.4 RequestMappings

2.4.1 RequestMappingHandlerMapping

我們在spring中通常使用的就是RequestMappingHandlerMapping,根據RequestMappingInfo,細化匹配條件,整體的查找過程如下:

AbstractHandlerMethodMapping實現接口getHandlerInternal

  1. 使用UrlPathHelper查找request對應的path

  2. 查找path對應的HandlerMethod

    2.1 從urlMap中直接等值匹配查找匹配條件RequestMappingInfo

    2.2 如果等值查找到匹配條件,將其添加到match條件中

    2.3 如果沒有找到匹配條件,使用所有的handlerMethod的RequestMappingInfo進行匹配

    2.4 對匹配到的Match進行排序,取出最高優先級的Match,并核對是否是唯一的最高優先級

    2.5 對匹配到條件,沒有匹配到條件的兩種情況,分別進行封裝

  3. 封裝HandlerMethod,確保bean中存的是實例    ContentNegotiationManager其中提供了針對miniType的match條件比較,使框架可以匹配到最合適的處理方法。

2.5 HttpMessageConverter

2.5.1 The Default Message Converters

SpringMvc默認會加載下列HttpMessageConverters:

?
1
2
3
4
5
6
7
8
9
10
ByteArrayHttpMessageConverter – converts byte arrays
StringHttpMessageConverter – converts Strings
ResourceHttpMessageConverter – converts org.springframework.core.io.Resource for any type of octet stream
SourceHttpMessageConverter – converts javax.xml.transform.Source
FormHttpMessageConverter – converts form data to/from a MultiValueMap<String, String>.
Jaxb2RootElementHttpMessageConverter – converts Java objects to/from XML (added only if JAXB2 is present on the classpath)
MappingJackson2HttpMessageConverter – converts JSON (added only if Jackson 2 is present on the classpath)
MappingJacksonHttpMessageConverter – converts JSON (added only if Jackson is present on the classpath)
AtomFeedHttpMessageConverter – converts Atom feeds (added only if Rome is present on the classpath)
RssChannelHttpMessageConverter – converts RSS feeds (added only if Rome is present on the classpath)

我們如果返回的是使用@ResponseBody來標識的,那么框架會使用HttpMessageConverter來處理返回值,默認的xmlCoverter不是特別好用,依賴返回實體對象上的@XmlRootElement注解,不是很方便所以引入輔助類庫,并自定義MessageConverter這樣可以直接將返回的對象處理成xml格式。

Gradle import library

?
1
2
compile group: 'org.springframework', name: 'spring-oxm', version: '4.3.9.RELEASE'
compile group: 'com.thoughtworks.xstream', name: 'xstream', version: '1.4.10'

configuration

?
1
2
3
4
5
6
7
8
9
10
11
12
13
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
 converters.add(createXmlHttpMessageConverter());
 super.configureMessageConverters(converters);
}
private HttpMessageConverter<Object> createXmlHttpMessageConverter() {
 MarshallingHttpMessageConverter xmlConverter =
   new MarshallingHttpMessageConverter();
 XStreamMarshaller xstreamMarshaller = new XStreamMarshaller();
 xmlConverter.setMarshaller(xstreamMarshaller);
 xmlConverter.setUnmarshaller(xstreamMarshaller);
 return xmlConverter;
}

2.6 View Resolution

2.6.1 頁面render(freemarker)

當需要返回頁面時就需要由合適的viewResolver來繪制畫面,這里采用freemarker作為頁面引擎。

Gradle import library

?
1
compile("org.springframework.boot:spring-boot-starter-freemarker")

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:http://xiagn825.github.io/2017/06/23/blog/

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品免费成人 | 久久精品日产高清版的功能介绍 | 日韩av一区二区三区在线观看 | 中国性xxx | 黄色av电影在线播放 | 天天鲁在线视频免费观看 | 黄视频免费在线 | av免费入口 | 一级片国产片 | 久久一区三区 | 成人短视频在线观看免费 | 国产免费一区二区三区网站免费 | 韩国三级日本三级香港三级黄 | 91伊人久久 | 国产精品亚洲一区二区三区在线观看 | 亚洲精品午夜国产va久久成人 | 韩国三级日本三级香港三级黄 | 国产99久久久国产精品下药 | 亚洲国产精品一 | 久久久久久久久久久久久久国产 | 亚洲欧美日韩一区二区三区在线观看 | 91九色蝌蚪国产 | 亚洲日本韩国在线观看 | 久久人人爽人人爽人人片av高清 | 欧美日韩电影在线 | 久久激情小视频 | 亚洲精品久久久久久下一站 | 国产在线一区二区三区 | 免费一区二区三区 | 久色成人网| 黄视频网站免费在线观看 | 国产欧美精品一区二区三区四区 | 成人一区二区在线观看视频 | 一本色道久久综合亚洲精品图片 | 中文字幕网址 | 欧美一区二区黄色 | 性aaa| 国产精品久久久久久久久久尿 | 欧美人与物videos另类 | 超久久 | 成人做爰高潮片免费视频韩国 |