IOC 之 Spring 統(tǒng)一資源加載策略

2018-10-06

原文推薦 死磕 Spring

統(tǒng)一資源:Resource

org.springframework.core.io.Resource 為 Spring 框架所有資源的抽象和訪問接口,它繼承 org.springframework.core.io.InputStreamSource接口。作為所有資源的統(tǒng)一抽象,Source 定義了一些通用的方法,由子類 AbstractResource 提供統(tǒng)一的默認實現(xiàn)。

Resource 根據(jù)資源的不同類型提供不同的具體實現(xiàn),如下:
FileSystemResource:對 java.io.File 類型資源的封裝,只要是跟 File 打交道的,基本上與 FileSystemResource 也可以打交道。支持文件和 URL 的形式,實現(xiàn) WritableResource 接口,且從 Spring Framework 5.0 開始,F(xiàn)ileSystemResource 使用NIO.2 API進行讀/寫交互

ByteArrayResource:對字節(jié)數(shù)組提供的數(shù)據(jù)的封裝。如果通過 InputStream 形式訪問該類型的資源,該實現(xiàn)會根據(jù)字節(jié)數(shù)組的數(shù)據(jù)構(gòu)造一個相應的 ByteArrayInputStream。

UrlResource:對 java.net.URL類型資源的封裝。內(nèi)部委派 URL 進行具體的資源操作。

ClassPathResource:class path 類型資源的實現(xiàn)。使用給定的 ClassLoader 或者給定的 Class 來加載資源。

InputStreamResource:將給定的 InputStream 作為一種資源的 Resource 的實現(xiàn)類。

AbstractResource 為 Resource 接口的默認實現(xiàn),它實現(xiàn)了 Resource 接口的大部分的公共實現(xiàn),作為 Resource 接口中的重中之重

如果我們想要實現(xiàn)自定義的 Resource,記住不要實現(xiàn) Resource 接口,而應該繼承 AbstractResource 抽象類,然后根據(jù)當前的具體資源特性覆蓋相應的方法即可。

統(tǒng)一資源定位:ResourceLoader

Resource 定義了統(tǒng)一的資源,那資源的加載則由 ResourceLoader 來統(tǒng)一定義。

ResourceLoader 接口提供兩個方法:getResource()、getClassLoader()。
getResource()根據(jù)所提供資源的路徑 location 返回 Resource 實例,但是它不確保該 Resource 一定存在,需要調(diào)用 Resource.exist()方法判斷。該方法支持以下模式的資源加載:
URL位置資源,如”file:C:/test.dat”
ClassPath位置資源,如”classpath:test.dat”
相對路徑資源,如”WEB-INF/test.dat”,此時返回的Resource實例根據(jù)實現(xiàn)不同而不同
該方法的主要實現(xiàn)是在其子類 DefaultResourceLoader中實現(xiàn),具體過程我們在分析DefaultResourceLoader時做詳細說明。
getClassLoader()返回 ClassLoader 實例,對于想要獲取 ResourceLoader 使用的 ClassLoader 用戶來說,可以直接調(diào)用該方法來獲取,
在分析 Resource 時,提到了一個類 ClassPathResource ,這個類是可以根據(jù)指定的 ClassLoader 來加載資源的。

....

總結(jié):

Spring 提供了 Resource 和 ResourceLoader 來統(tǒng)一抽象整個資源及其定位。使得資源與資源的定位有了一個更加清晰的界限,并且提供了合適的 Default 類,使得自定義實現(xiàn)更加方便和清晰。
DefaultResource 為 Resource 的默認實現(xiàn),它對 Resource 接口做了一個統(tǒng)一的實現(xiàn),子類繼承該類后只需要覆蓋相應的方法即可,同時對于自定義的 Resource 我們也是繼承該類。
DefaultResourceLoader 同樣也是 ResourceLoader 的默認實現(xiàn),在自定 ResourceLoader 的時候我們除了可以繼承該類外還可以實現(xiàn) ProtocolResolver 接口來實現(xiàn)自定資源加載協(xié)議。
DefaultResourceLoader 每次只能返回單一的資源,所以 Spring 針對這個提供了另外一個接口 ResourcePatternResolver ,該接口提供了根據(jù)指定的 locationPattern 返回多個資源的策略。其子類 PathMatchingResourcePatternResolver 是一個集大成者的 ResourceLoader ,因為它即實現(xiàn)了 Resource getResource(String location) 也實現(xiàn)了 Resource[] getResources(String locationPattern)。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,618評論 19 139
  • 本文是我自己在秋招復習時的讀書筆記,整理的知識點,也是為了防止忘記,尊重勞動成果,轉(zhuǎn)載注明出處哦!如果你也喜歡,那...
    波波波先森閱讀 12,453評論 6 86
  • 作為Spring提供的較之BeanFactory更為先進的IoC容器實現(xiàn),ApplicationContext除了...
    好好學習Sun閱讀 873評論 0 2
  • 模塊化解決的問題 全局變量的災難. 函數(shù)命名沖突 依賴關(guān)系不好管理 模塊化發(fā)展過程中的 7 種方式 一個文件、一個...
    Mr無愧于心閱讀 1,821評論 1 4
  • 昨天上午和一大學室友一起去了廣濟寺,然后中午吃飯聊天,談到了大學時候的每一個宿舍,也談到了我們到了攢錢的年齡。她...
    槿瓊閱讀 201評論 0 0

友情鏈接更多精彩內(nèi)容