欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Spring中XMLschema擴展機制的原理是什么

Spring中XML schema擴展機制的原理是什么?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

在鎮(zhèn)平等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計、成都做網(wǎng)站 網(wǎng)站設(shè)計制作按需網(wǎng)站策劃,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計,成都營銷網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站制作,鎮(zhèn)平網(wǎng)站建設(shè)費用合理。

自定義 XML 擴展

為了搞懂 Spring 的 XML 擴展機制,最直接的方式便是實現(xiàn)一個自定義的擴展。實現(xiàn)的步驟也非常簡單,分為四步:

Spring中XML schema擴展機制的原理是什么

  • 編寫一個 XML schema 文件描述的你節(jié)點元素。

  • 編寫一個 NamespaceHandler 的實現(xiàn)類

  • 編寫一個或者多個 BeanDefinitionParser 的實現(xiàn) (關(guān)鍵步驟).

  • 注冊上述的 schema 和 handler。

我們的目的便是想要實現(xiàn)一個 kirito XML schema,我們的項目中可以自定義 kirito.xml,在其中會以 kirito 為標簽來定義不同的類,并在最終的測試代碼中驗證這些聲明在 kirito.xml 的類是否被 Spring 成功加載。大概像這樣,是不是和 dubbo.xml 的格式很像呢?

Spring中XML schema擴展機制的原理是什么

動手實現(xiàn)

有了明確的目標,我們逐步開展自己的工作。

1 編寫kirito.xsd

resources/META-INF/kirito.xsd

<?xml version="1.0" encoding="UTF-8"?>
<xsd:schema xmlns="http://www.cnkirito.moe/schema/kirito"
   xmlns:xsd="http://www.w3.org/2001/XMLSchema"
   xmlns:beans="http://www.springframework.org/schema/beans"
   targetNamespace="http://www.cnkirito.moe/schema/kirito"> ①

 <xsd:import namespace="http://www.springframework.org/schema/beans"/>

 <xsd:element name="application"> ②
  <xsd:complexType>
   <xsd:complexContent>
    <xsd:extension base="beans:identifiedType">
     <xsd:attribute name="name" type="xsd:string" use="required"/>
    </xsd:extension>
   </xsd:complexContent>
  </xsd:complexType>
 </xsd:element>

 <xsd:element name="service"> ②
  <xsd:complexType>
   <xsd:complexContent>
    <xsd:extension base="beans:identifiedType">
     <xsd:attribute name="name" type="xsd:string" use="required"/>
    </xsd:extension>
   </xsd:complexContent>
  </xsd:complexType>
 </xsd:element>


</xsd:schema>

① 注意這里的 targetNamespace="http://www.cnkirito.moe/schema/kirito" 這便是之后 kirito 標簽的關(guān)鍵點。

② kirito.xsd 定義了兩個元素: application 和 service,出于簡單考慮,都只有一個 name 字段。

schema 的意義在于它可以和 eclipse/IDEA 這樣智能化的集成開發(fā)環(huán)境形成很好的搭配,在編輯 XML 的過程中,用戶可以獲得告警和提示。 如果配置得當,可以使用自動完成功能讓用戶在事先定義好的枚舉類型中進行選擇。

2 編寫KiritoNamespaceHandler

public class KiritoNamespaceHandler extends NamespaceHandlerSupport {

 @Override
 public void init() {
  super.registerBeanDefinitionParser("application", new KiritoBeanDefinitionParser(ApplicationConfig.class));
  super.registerBeanDefinitionParser("service", new KiritoBeanDefinitionParser(ServiceBean.class));
 }
}

完成 schema 之后,還需要一個 NamespaceHandler 來幫助 Spring 解析 XML 中不同命名空間的各類元素。

<kirito:application name="kirito"/>
<dubbo:application name="dubbo"/>
<motan:application name="motan"/>

不同的命名空間需要不同的 NamespaceHandler 來處理,在今天的示例中,我們使用 KiritoNamespaceHandler 來解析 kirito 命名空間。KiritoNamespaceHandler 繼承自 NamespaceHandlerSupport 類,并在其 init() 方法中注冊了兩個 BeanDefinitionParser ,用于解析 kirito 命名空間/kirito.xsd 約束中定義的兩個元素:application,service。BeanDefinitionParser 是下一步的主角,我們暫且跳過,將重心放在父類 NamespaceHandlerSupport 之上。

public interface NamespaceHandler {
 void init();
 BeanDefinition parse(Element element, ParserContext parserContext);
 BeanDefinitionHolder decorate(Node source, BeanDefinitionHolder definition, ParserContext parserContext);
}

NamespaceHandlerSupport 是 NamespaceHandler 命名空間處理器的抽象實現(xiàn),我粗略看了NamespaceHandler 的幾個實現(xiàn)類,parse 和 decorate 方法可以完成元素節(jié)點的組裝并通過 ParserContext 注冊到 Ioc 容器中,但實際我們并沒有調(diào)用這兩個方法,而是通過 init() 方法注冊 BeanDefinitionParser 來完成解析節(jié)點以及注冊 Bean 的工作,所以對于 NamespaceHandler,我們主要關(guān)心 init 中注冊的兩個 BeanDefinitionParser 即可。

3 編寫KiritoBeanDefinitionParser

在文章開始我們便標記到 BeanDefinitionParser 是最為關(guān)鍵的一環(huán),每一個 BeanDefinitionParser 實現(xiàn)類都負責(zé)一個映射,將一個 XML 節(jié)點解析成 IOC 容器中的一個實體類。

public class KiritoBeanDefinitionParser implements BeanDefinitionParser {

 private final Class<?> beanClass;

 public KiritoBeanDefinitionParser(Class<?> beanClass) {
  this.beanClass = beanClass;
 }

 private static BeanDefinition parse(Element element, ParserContext parserContext, Class<?> beanClass) {
  RootBeanDefinition beanDefinition = new RootBeanDefinition();
  beanDefinition.setBeanClass(beanClass);
  beanDefinition.setLazyInit(false);
  String name = element.getAttribute("name");
  beanDefinition.getPropertyValues().addPropertyValue("name", name);
  parserContext.getRegistry().registerBeanDefinition(name, beanDefinition);
  return beanDefinition;
 }

 @Override
 public BeanDefinition parse(Element element, ParserContext parserContext) {
  return parse(element, parserContext, beanClass);
 }
}

由于我們的實體類是非常簡單的,所以不存在很復(fù)雜的解析代碼,而實際項目中,往往需要大量的解析步驟。parse 方法會解析一個個 XML 中的元素,使用 RootBeanDefinition 組裝成對象,并最終通過 parserContext 注冊到 IOC 容器中。

至此,我們便完成了 XML 文件中定義的對象到 IOC 容器的映射。

4 注冊schema和handler

最后一步還需要通知 Spring,告知其自定義 schema 的所在之處以及對應(yīng)的處理器。

resources/META-INF/spring.handlers

http\://www.cnkirito.moe/schema/kirito=moe.cnkirito.sample.xsd.KiritoNamespaceHandler

resources/META-INF/spring.schemas

http\://www.cnkirito.moe/schema/kirito/kirito.xsd=META-INF/kirito.xsd

沒有太多可以說的,需要遵守 Spring 的約定。

至此一個自定義的 XML schema 便擴展完成了,隨后來驗證一下。

驗證擴展

我們首先定義好 kirito.xml

<?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:kirito="http://www.cnkirito.moe/schema/kirito"
  xsi:schemaLocation=" http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.cnkirito.moe/schema/kirito
        http://www.cnkirito.moe/schema/kirito/kirito.xsd">

 <kirito:application name="kirito-demo-application"/>

 <kirito:service name="kirito-demo-service"/>

</beans>

使用 Spring 去加載它,并驗證 IOC 容器中是否存在注冊成功的 Bean。

@SpringBootApplication
@ImportResource(locations = {"classpath:kirito.xml"})
public class XmlSchemaAuthoringSampleApplication {

 public static void main(String[] args) {
  ConfigurableApplicationContext applicationContext = SpringApplication.run(XmlSchemaAuthoringSampleApplication.class, args);
  ServiceBean serviceBean = applicationContext.getBean(ServiceBean.class);
  System.out.println(serviceBean.getName());
  ApplicationConfig applicationConfig = applicationContext.getBean(ApplicationConfig.class);
  System.out.println(applicationConfig.getName());
 }
}

觀察控制臺的輸出:

kirito-demo-service
kirito-demo-application

一個基礎(chǔ)的基于 XML schema 的擴展便完成了。

Dubbo中的XML schema擴展

最后我們以 Dubbo 為例,看看一個成熟的 XML schema 擴展是如何被應(yīng)用的。

Spring中XML schema擴展機制的原理是什么

看完上述內(nèi)容,你們掌握Spring中XML schema擴展機制的原理是什么的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

分享文章:Spring中XMLschema擴展機制的原理是什么
分享路徑:http://aaarwkj.com/article22/pdecjc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機、移動網(wǎng)站建設(shè)、企業(yè)建站、ChatGPT網(wǎng)站內(nèi)鏈、Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)
91精品超碰人人在线公开| 欧美另类亚洲综合久青草| 日韩久久精品免费视频| 国产婷婷成人久久av免费高清| 亚洲少妇插进去综合网| 日韩精品视频播放一区| 国产一区二区三区自拍| 国语对白精品视频在线| 亚洲熟女乱妇爽到高潮| 国产看片色网站亚洲av| 国产av一级二级三级最新精品| 一级黄片一区二区三区| 91精品国产综合久久香蕉麻豆| 日韩精品成人区中文字幕| 麻豆专区一区二区三区| 欧美一区二区三在线| 亚洲综合一区国产精品| 国产三级精品三级在线播放| 日韩精品一区二区三区四区在线视频 | 亚洲精品一区二区三区小| 在线高清视频无卡不码| av熟女乱一区二区三区| 四虎在线永久观看视频| 日韩中文字幕 在线播放| 亚洲国产日韩欧美在线| 夫妻性生活视频全过程| 国产模特一区二区三区| 农村人妻一区二区三区视频 | 日本欧美国产污黄在线观看| 色偷偷91综合久久噜噜| 日本女优久久精品观看| 99热精品成人免费观看| 97在线观看全部视频| 亚洲三级av在线播放| 久久精品色妇熟妇丰满人妻| 亚洲国产在线一区二区| 日本特黄特色高清免费大片| 九九九热免费在线观看| 亚洲欧美日韩有码一区| 91国产熟女自拍视频| 国产精品视频在线播放|