Spring中如何使用責任鏈模式?
至于責任鏈模式,有兩種形式。一種是通過外部調用來控制鏈條各節點的調用,從而在鏈條各節點之間進行切換;另一種是鏈的每個節點自由控制是否繼續傳遞鏈的進度。這種典型的使用模式就是N:。
在上面的控制邏輯中,過濾器只能通過Spring的自動注入來獲得,而這里,注入了一個,即如果我們需要參與責任鏈的過濾,只需要將其聲明為Spring容器管理的bean即可。
這種責任鏈設計方法的優點是鏈的控制相對簡單,只需要實現一個統一的接口,基本上可以滿足大部分的邏輯控制,但是可以對于一些需要動態調整鏈的需求,不做任何事情。比如執行到某個節點后,需要動態判斷是執行下一個節點,還是執行一些分叉節點等等。這時候我們就需要把鏈節點的轉移交給各個節點了。
2.節點控制模式
節點控制調用有三個主要的控制點:Handler、HandlerContext和Pipeline。Handler用于編寫具體的業務代碼;HandlerContext主要用于Handler包裝并用于控制下一個節點的調用;管道主要用于控制任務查詢、任務過濾、任務執行等全過程調用。這些流程的整體邏輯控制由Pipeline控制,每個流程包含一系列子流程,由HandlerContext和Handler進行排序。該責任鏈管控模式的整體邏輯如下圖所示:
從圖中可以看出,我們通過對象對整個流程進行抽象,主要分為查詢任務、過濾任務、執行任務三個步驟。在每一步中,我們使用一系列的鏈式調用。需要注意的是,我們每次調用鏈的下一個節點都是通過特定的處理程序來完成的,也就是說,是否調用鏈的下一個節點是通過業務實現者來動態控制的。
關于這種模式的設計,首先需要強調的是界面設計,具體如下:
這里的接口主要是具體業務邏輯的抽象,需要說明以下幾點:
在上圖中,每個級別都有一個對應的方法。當需要具體的業務處理時,用戶只需要聲明一個bean來具體實現當前業務需要處理的級別的方法,而不用考慮其他邏輯。在每一級的方法中,第一個參數是一個類型,主要用于流程控制,比如當前級的調用鏈是否需要向下傳遞,其中鏈的傳遞主要通過方法進行;每一級方法都有一個默認的實現,默認的實現是向下傳遞鏈的調用;每個都有一個方法和一個方法,分別用于所有調用完成后的異??刂坪颓謇怼_@里的異??刂浦饕遣东@當前進程中的異常,而方保證在所有步驟之后都會進行調用,不管是否拋出異常;對于的使用,我們希望達到的是,適用方只需要實現接口,用一個標注把它標記為bean,不用考慮整個組裝和流程控制。這樣既保留了每個彈簧提供的便利,又利用了圖案的靈活性。在上面的流代碼中,我們注意到每一層都有一個方法,用于傳輸與鏈相關的控制信息。在這里,讓我們讓我們看看它的源代碼:
在中,我們需要解釋以下幾點:
之前接口默認實現的方法都是委托給對應的方法進行調用,我們需要注意的是,在傳遞給方法的參數中,傳入的對象都是通過方法獲得的。也就是說,當我們在中調用方法時,我們正在調用當前處理程序的下一個handl。Er對應的是層級法,通過這種我們實現了鏈的向下傳遞。上一點我們說了,如果想讓鏈往下傳,只需要調用方法就可以了。也就是說,如果我們在某個地方,如果根據業務已經調用了當前級別,沒有必要調用后續的,那么我們就不不需要調用該方法;在中,我們還實現了方法,主要用于外部調用打開每一級的鏈;在每個方法中,我們使用try…catch來捕捉當前級別的調用所拋出的異常,然后調用方法來處理異常,這就是我們前面所說的。如果我們想處理當前的異常,我們只需要實現其中的方法,異常捕獲過程就是在這里處理的。在聲明的時候,我們需要注意到它被標注了和注釋,說明我們的是Spring管理的bean,由于我們每個人實際上都是由一個維護的,所以這里必須聲明為類型。這樣我們也有了Spring相關bean的功能,可以根據業務需求做一些額外的處理。前面,我們講解了的具體實施以及實施過程中應該注意的問題。讓讓我們看看過程控制是如何實現的。以下是接口的定義:
本文主要定義了一個接口,它定義了一系列的層次調用,是每一層的入口方法。以下是此接口的實現類:
關于的實現,主要有以下幾點需要說明:
注釋和用于注釋它。前一個注釋用于將它聲明為由Spring容器管理的bean,后一個注釋用于描述它是多實例類型。顯然,這是有狀態的。這里需要說明的是,有狀態主要是因為我們可能會根據業務情況動態調整一個鏈的節點狀態,這里的和對象與具體業務相關,所以必須聲明為類型;在上面的例子中,對象是在構造的時候傳入的,對象是在循環的過程中生成的。比如鏈的調用完成后,需要通過外部請求獲取一個對象,從而進行整個后續處理;這里我們已經意識到,并且知道這些bean是由Spring管理的,我們的下一個問題主要是如何組裝整個鏈。這里的組裝方法比較簡單,主要需要解決兩個問題:
對于后期寫業務代碼的人來說,只需要實現一個接口,不需要處理所有與鏈相關的邏輯,所以我們需要獲取所有的bean實現了接口的;通過封裝實現接口的bean,然后將其添加到。這里的第一個問題更容易處理,因為接口可以通過ApplicationContext獲得和實現。第二個問題可以通過聲明一個實現BeanPostProc
spring入門詳解?
一.Spring概述
Spring是DI/IOC和AOP的輕量級容器框架。
??輕量級:簡單易用,一般來說功能不強大(但spring功能強大)
??DI(依賴注入):動態地為一個對象提供它需要的其他對象,也可以是對象的一個屬性字段。任務。(依賴注入分為xml注入和注釋注入)
??IOC:spring控制一個對象的生命周期(創建、銷毀)。
??AOP(面向方面編程):解決重復代碼。提取相同的邏輯,即將業務邏輯從應用服務中分離出來。然后它以攔截的作用于方法的不同位置。
第二,Spring入門
1.介紹圖書館
引導包裝時請注意?,F在使用Spring,我們需要完成最小的guide包,也就是我們會導入任何我們需要的jar包,使用其他函數,然后添加相應的jar包。這個包對理解框架很有幫助:
2.導入Spring配置文件
1.在類路徑的根目錄中創建新的applicationContext.xml配置文件??梢宰远x文件名,但通常使用applicationCont:xsi##34
xsieCHO4-@.comschemalocation#
#34gt
tltbeanid#34...#34類#34...#34gt
tlt!-此bean的協作者和配置在此處-gt
tlt/beangt
lt/beansgt
一個
2
三
四
五
六
七
八
九
10
一個
2
三
四
五
六
七
八
九
10
3.編寫邏輯代碼
公共類MyBean{
tpublicvoidhello(){
你好,春天...#34)
t}
}
一個
2
三
四
五
六
一個
2
三
四
五
六
4.把這個類交給Spring來管理,就是在Spring容器中注冊。
在配置文件中將這個Java類交給Spring進行管理。在applicationContext.xml中配置
ltbeans
ltbeanid#34mybean#34class#_01_#34gtlt/beangt
lt/beansgt
一個
2
三
四
一個
2
三
四
5.5的實例化。彈簧容器
有兩種Spring容器對象:BeanFactory和ApplicationCont:Beanfactory,顧名思義,它是一個制造Bean的工廠。
T*和Beanfactory來創建對象,并且必須獲取配置文件中的數據。
T*因為:我們的第一步是讀取配置文件,并將其獲取到BeanFactoryFactoryT。
t*/
t
T//第一步:讀取資源文件。
tResource資源新建classpathresource(#34applicationcontext.XML#34)
T//第二步:獲取核心對象BeanFactory。
tBeanFactory工廠新的XmlBeanFactory(資源)
}
一個
2
三
四
五
六
七
八
九
10
11
12
13
14
15
16
一個
2
三
四
五
六
七
八
九
10
11
12
13
14
15
16
應用程序上下文(推薦)
@測試
publicvoidt:Beanfactory,顧名思義,它是一個制造Bean的工廠。
T*和Beanfactory來創建對象,并且必須獲取配置文件中的數據。
T*因為:我們的第一步是讀取配置文件,并將其獲取到BeanFactoryFactoryT。
t*/
t
T//在加載項目的類路徑下實例化配置文件。
tStringconf#34applicationcontext.XML#34
tApplicationContext工廠新的classpathmlaplicationcontext(conf)
}
一個
2
三
四
五
六
七
八
九
10
11
12
13
14
15
一個
2
三
四
五
六
七
八
九
10
11
12
13
14
15
6.如何獲得對象
方法一:直接通過id獲取對應的Bean對象。
//通過xml中配置的id獲取對象。
MyBeanbean(MyBean)(#34myBean#34)
(豆子)
一個
2
三
四
一個
2
三
四
方法二:通過對象的id和類對象獲取Bean對象(推薦)。
//通過對象的id和類獲取Bean對象。
MyBeanbean(#34myBean#34,)
(豆子)
一個
2
三
四
一個
2
三
四
第三,Spring依賴注入
1.xml注入
顧名思義:它是用xml配置的,但是這個方法必須有對應的setter方法。所有這種注入方法也被稱為屬性注入或setter方法注入。
公共類MyBean{
其他豆類
tpublicvoidhello(){
ttotherBean.hello()
t}
publicvoidsetOtherBean(otherbeanotherbean){
這個。其他豆類
}
}
一個
2
三
四
五
六
七
八
九
10
一個
2
三
四
五
六
七
八
九
10
公共類OtherBean{
tpublicvoidhello(){
(#34以太網你好#34)
t}
}
一個
2
三
四
五
六
一個
2
三
四
五
六
//xml配置:
ltbeanid#34otherbean#34class##34gtlt/beangt
ltbeanid#34mybean#34class##34gt
ltpropertyname#34otherbean#34ref#34otherbean#34gtlt/propertygt
lt/beangt
一個
2
三
四
五
六
一個
2
三
四
五
六
2.注釋注入
顧名思義:注入是通過評論實現的。這樣,可以在setter方法或字段上編寫注釋。如果它們寫在字段上,就不需要setter方法。
2.1選項1:使用@Autowired
@Autowired對春天的評論
公共類MyBean{
其他豆類
tpublicvoidhello(){
ttotherBean.hello()
t}
}
公共類OtherBean{
tpublicvoidhello(){
(#34另一個他第34頁)
t}
}
一個
2
三
四
五
六
七
八
九
10
11
12
13
14
一個
2
三
四
五
六
七
八
九
10
11
12
13
14
//xml配置:
ltbeanid#34otherbean#34class##34gtlt/beangt
ltbeanid#34mybean#34class##34gtlt/beangt
一個
2
三
一個
2
三
2.2選項2:使用@Resource
公共類MyBean{
@資源
其他豆類
tpublicvoidhello(){
ttotherBean.hello()
t}
}
公共類OtherBean{
tpublicvoidhello(){
(#34以太網你好#34)
t}
}
一個
2
三
四
五
六
七
八
九
10
11
12
13
14
一個
2
三
四
五
六
七
八
九
10
11
12
13
14
和@資源。
@Autowired:先按默認類型再按名稱匹配。
@Resource:默認按名稱匹配,然后按類型匹配。