Spring Boot中擴(kuò)展XML請(qǐng)求與響應(yīng)的支持詳解
前言
在之前的所有Spring Boot教程中,我們都只提到和用到了針對(duì)HTML和JSON格式的請(qǐng)求與響應(yīng)處理。那么對(duì)于XML格式的請(qǐng)求要如何快速的在Controller中包裝成對(duì)象,以及如何以XML的格式返回一個(gè)對(duì)象呢?
什么是xml文件格式
我們要給對(duì)方傳輸一段數(shù)據(jù),數(shù)據(jù)內(nèi)容是“too young,too simple,sometimes naive”,要將這段話按照屬性拆分為三個(gè)數(shù)據(jù)的話,就是,年齡too young,閱歷too simple,結(jié)果sometimes naive。我們都知道程序不像人,可以體會(huì)字面意思,并自動(dòng)拆分出數(shù)據(jù),因此,我們需要幫助程序做拆分,因此出現(xiàn)了各種各樣的數(shù)據(jù)格式以及拆分方式。比如,可以是這樣的數(shù)據(jù)為“too young,too simple,sometimes naive”然后按照逗號(hào)拆分,第一部分為年齡,第二部分為閱歷,第三部分為結(jié)果。也可以是這樣的數(shù)據(jù)為“too_young* too_simple*sometimes_naive”從數(shù)據(jù)開(kāi)頭開(kāi)始截取前面十一個(gè)字符,去掉號(hào)并把下劃線替換為空格作為第一部分,再截取接下來(lái)的十一個(gè)字符同樣去掉并替換下劃線為空格作為第二部分,最后把剩下的字符同樣去號(hào)體會(huì)空格作為第三部分。這兩種方式都可以用來(lái)容納數(shù)據(jù)并能夠被解析,但是不直觀,通用性也不好,而且如果出現(xiàn)超過(guò)限定字?jǐn)?shù)的字符串就容納不了,也可能出現(xiàn)數(shù)據(jù)本身就下劃線字符導(dǎo)致需要做轉(zhuǎn)義?;谶@種情況,出現(xiàn)了xml這種數(shù)據(jù)格式, 上面的數(shù)據(jù)用XML表示的話可以是這樣
實(shí)現(xiàn)原理:消息轉(zhuǎn)換器(Message Converter)
在擴(kuò)展上述問(wèn)題之前,我們先要知道Spring Boot中處理HTTP請(qǐng)求的實(shí)現(xiàn)是采用的Spring MVC。而在Spring MVC中有一個(gè)消息轉(zhuǎn)換器這個(gè)概念,它主要負(fù)責(zé)處理各種不同格式的請(qǐng)求數(shù)據(jù)進(jìn)行處理,并包轉(zhuǎn)換成對(duì)象,以提供更好的編程體驗(yàn)。
在Spring MVC中定義了HttpMessageConverter接口,抽象了消息轉(zhuǎn)換器對(duì)類型的判斷、對(duì)讀寫的判斷與操作,具體可見(jiàn)如下定義:
public interface HttpMessageConverter<T> {
boolean canRead(Class<?> clazz, @Nullable MediaType mediaType);
boolean canWrite(Class<?> clazz, @Nullable MediaType mediaType);
List<MediaType> getSupportedMediaTypes();
T read(Class<? extends T> clazz, HttpInputMessage inputMessage) throws IOException, HttpMessageNotReadableException;
void write(T t, @Nullable MediaType contentType, HttpOutputMessage outputMessage) throws IOException, HttpMessageNotWritableException;
}
眾所周知,HTTP請(qǐng)求的Content-Type有各種不同格式定義,如果要支持Xml格式的消息轉(zhuǎn)換,就必須要使用對(duì)應(yīng)的轉(zhuǎn)換器。Spring MVC中默認(rèn)已經(jīng)有一套采用Jackson實(shí)現(xiàn)的轉(zhuǎn)換器MappingJackson2XmlHttpMessageConverter。
擴(kuò)展實(shí)現(xiàn)
第一步:引入Xml消息轉(zhuǎn)換器
在傳統(tǒng)Spring應(yīng)用中,我們可以通過(guò)如下配置加入對(duì)Xml格式數(shù)據(jù)的消息轉(zhuǎn)換實(shí)現(xiàn):
@Configuration
public class MessageConverterConfig1 extends WebMvcConfigurerAdapter {
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
Jackson2ObjectMapperBuilder builder = Jackson2ObjectMapperBuilder.xml();
builder.indentOutput(true);
converters.add(new MappingJackson2XmlHttpMessageConverter(builder.build()));
}
}
在Spring Boot應(yīng)用不用像上面這么麻煩,只需要加入jackson-dataformat-xml依賴,Spring Boot就會(huì)自動(dòng)引入MappingJackson2XmlHttpMessageConverter的實(shí)現(xiàn):
<dependency> <groupId>com.fasterxml.jackson.dataformat</groupId> <artifactId>jackson-dataformat-xml</artifactId> </dependency>
同時(shí),為了配置Xml數(shù)據(jù)與維護(hù)對(duì)象屬性的關(guān)系所要使用的注解也在上述依賴中,所以這個(gè)依賴也是必須的。
第二步:定義對(duì)象與Xml的關(guān)系
做好了基礎(chǔ)擴(kuò)展之后,下面就可以定義Xml內(nèi)容對(duì)應(yīng)的Java對(duì)象了,比如:
@Data
@NoArgsConstructor
@AllArgsConstructor
@JacksonXmlRootElement(localName = "User")
public class User {
@JacksonXmlProperty(localName = "name")
private String name;
@JacksonXmlProperty(localName = "age")
private Integer age;
}
其中:@Data、@NoArgsConstructor、@AllArgsConstructor是lombok簡(jiǎn)化代碼的注解,主要用于生成get、set以及構(gòu)造函數(shù)。@JacksonXmlRootElement、@JacksonXmlProperty注解是用來(lái)維護(hù)對(duì)象屬性在xml中的對(duì)應(yīng)關(guān)系。
上述配置的User對(duì)象,其可以映射的Xml樣例如下(后續(xù)可以使用上述xml來(lái)請(qǐng)求接口):
<User> <name>aaaa</name> <age>10</age> </User>
第三步:創(chuàng)建接收xml請(qǐng)求的接口
完成了要轉(zhuǎn)換的對(duì)象之后,可以編寫一個(gè)接口來(lái)接收xml并返回xml,比如:
@Controller
public class UserController {
@PostMapping(value = "/user",
consumes = MediaType.APPLICATION_XML_VALUE,
produces = MediaType.APPLICATION_XML_VALUE)
@ResponseBody
public User create(@RequestBody User user) {
user.setName("didispace.com : " + user.getName());
user.setAge(user.getAge() + 100);
return user;
}
}
最后,啟動(dòng)Spring Boot應(yīng)用,通過(guò)POSTMAN等請(qǐng)求工具,嘗試一下這個(gè)接口,可以看到請(qǐng)求Xml,并且返回了經(jīng)過(guò)處理后的Xml內(nèi)容。
案例代碼
可以通過(guò)下面兩個(gè)倉(cāng)庫(kù)中查閱chapter3-1-8目錄:
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
java數(shù)據(jù)結(jié)構(gòu)ArrayList詳解
本文詳細(xì)講解了java數(shù)據(jù)結(jié)構(gòu)ArrayList的用法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12
java實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘并設(shè)置鬧鐘功能
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘并設(shè)置鬧鐘功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
Java中LinkedList詳解和使用示例_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
LinkedList 是一個(gè)繼承于AbstractSequentialList的雙向鏈表。它也可以被當(dāng)作堆棧、隊(duì)列或雙端隊(duì)列進(jìn)行操作。接下來(lái)通過(guò)示例代碼給大家詳細(xì)介紹java中l(wèi)inkedlist的使用,需要的朋友參考下吧2017-05-05
springboot項(xiàng)目打包成jar包的圖文教程
有時(shí)候我們會(huì)用IDEA來(lái)開(kāi)發(fā)一些小工具,需要打成可運(yùn)行的JAR包,這篇文章主要給大家介紹了關(guān)于springboot項(xiàng)目打包成jar包的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
SpringCloud feign服務(wù)熔斷下的異常處理操作
這篇文章主要介紹了SpringCloud feign服務(wù)熔斷下的異常處理操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06
Spring?Boot?集成Elasticsearch模塊實(shí)現(xiàn)簡(jiǎn)單查詢功能
本文講解了Spring?Boot集成Elasticsearch采用的是ES模板的方式實(shí)現(xiàn)基礎(chǔ)查詢,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2022-06-06
springboot使用redis緩存亂碼(key或者value亂碼)的解決
在通過(guò)springboot緩存數(shù)據(jù)的時(shí)候,發(fā)現(xiàn)key是一堆很不友好的東西,本文主要介紹了springboot使用redis緩存亂碼(key或者value亂碼)的解決,感興趣的可以了解一下2023-11-11
SpringBoot?AnnotationUtils工具類的使用實(shí)例詳解
這篇文章主要介紹了SpringBoot?AnnotationUtils工具類的使用,使用自定義注解標(biāo)記業(yè)務(wù)方法,原生Java獲取注解及AnnotationUtils工具類獲取方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
SpringCloud之Config配置中心與Redis分布式鎖詳解
這篇文章主要給大家介紹了SpringCloud Alibaba中Config配置中心,Redis分布式鎖,文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考閱讀2023-05-05

