Java中的责任链设计模式
在本教程中,我們將學(xué)習(xí)如何在Java中實(shí)現(xiàn)責(zé)任鏈模式。
“責(zé)任鏈”設(shè)計(jì)模式涉及到擁有一系列負(fù)責(zé)處理請求的對象鏈。 當(dāng)客戶端發(fā)送請求時(shí),第一個(gè)處理程序?qū)L試處理該請求。 如果可以處理,則請求處理在此結(jié)束。 但是,如果處理程序無法處理用戶請求,則它將轉(zhuǎn)到鏈中的下一個(gè)處理程序。 該過程將繼續(xù)進(jìn)行,直到鏈中的任何一個(gè)處理程序成功處理請求或鏈結(jié)束為止。 如果整個(gè)鏈條都無法處理該請求,則意味著該請求仍然無法滿足。
為什么要使用責(zé)任鏈?
責(zé)任鏈?zhǔn)俏覀冘浖袠I(yè)中非常重要的設(shè)計(jì)模式。 它具有以下優(yōu)點(diǎn):
- 由于用戶不需要關(guān)心哪個(gè)對象將處理其請求,因此它促進(jìn)了用戶與系統(tǒng)之間的松散耦合。
- Java異常處理機(jī)制也利用了這種模式。 如果找不到合適的catch塊,則將請求委托給調(diào)用方方法進(jìn)行處理,直到找到合適的處理程序?yàn)橹?
- 通過讓請求通過一系列過濾器,該模式還可以找到其在過濾用戶請求中的應(yīng)用程序
UML表示形式:
責(zé)任鏈模式的UML表示類似于:
在這里,我們具有以下類型的對象:
- 客戶:發(fā)出用戶請求的代碼
- 處理程序: 抽象超類或定義請求處理程序方法的接口
- ConcreteHandler: Handler的實(shí)現(xiàn)類
處理程序?qū)ο笤阪溨袕囊粋€(gè)連接到另一個(gè)。 而且, 每個(gè)具體處理程序都以其自己獨(dú)特的方式處理請求。
定義抽象處理程序:
讓我們使用責(zé)任鏈實(shí)現(xiàn)請求過濾邏輯。
首先,我們將定義一個(gè)抽象的RequestFilter類:
public abstract class RequestFilter { ????private RequestFilter next; ?public RequestFilter(RequestFilter next) { this .next = next; } ?public boolean doFilter(HttpServletRequest request); ????public void getNext() { return this .next; } .next; } }定義具體處理程序:
現(xiàn)在,讓我們定義鏈中的第一個(gè)過濾器類,它將阻止來自可疑IP地址的請求:
public class SuspiciousRequestFilter extends RequestFilter { ????public SuspiciousRequestFilter(RequestFilter next) { super (next); } ??public boolean doFilter(HttpServletRequest request) { if (hasMaliciousIntent(request.getRemoteAddr()) { //blocks the request return false ; } else if (next == null ) { //filter chain ended return false ; } return this .getNext().doFilter(request); } ?public boolean hasMaliciousIntent(String ipAddress) { ... } }同樣,讓我們??定義鏈中的第二個(gè)過濾器,它將阻止未授權(quán)的請求:
public class UnauthorizedRequestFilter extends RequestFilter { ????public UnauthorizedRequestFilter(RequestFilter next) { super (next); } ??public boolean doFilter(HttpServletRequest request) { if (isUserUnauthorized(request)) { //blocks the request return false ; } else if (next == null ) { //filter chain ended return false ; } return this .getNext().doFilter(request); } ?public boolean isUserUnauthorized(HttpServletRequest request) { ... } }最后一個(gè)過濾器將識(shí)別和阻止嘗試登錄次數(shù)超出的用戶:
public class ExceededLoginAttemptsRequestFilter extends RequestFilter { ????public ExceededLoginAttemptsRequestFilter(RequestFilter next) { super (next); } ??public boolean doFilter(HttpServletRequest request) { if (hasExceededLoginAttempts(request)) { //blocks the request return false ; } else if (next == null ) { //filter chain ended return false ; } return this .getNext().doFilter(request); } ?public boolean hasExceededLoginAttempts(HttpServletRequest request) { ... } }調(diào)用鏈:
最后,是時(shí)候?qū)⑺鼈兙幙棾涉溋?#xff1a;
HttpServletRequest httpServletRequest = ... ? //the last filter in our chain RequestFilter exceededAttemptsFilter = new ExceededLoginAttemptsRequestFilter( null ); ? RequestFilter unauthorizedFilter = new UnauthorizedRequestFilter(exceededAttemptsFilter); RequestFilter suspiciousActivityFilter = new SuspiciousRequestFilter(unauthorizedFilter); ? suspiciousActivityFilter.doFilter(httpServletRequest);在這里,每個(gè)用戶請求將遵循以下過濾鏈:
這些過濾條件之一一旦被匹配,匹配的過濾器就會(huì)過濾掉該用戶請求。 這也意味著剩余的鏈將被跳過。
結(jié)論:
在本教程中,我們學(xué)習(xí)了如何以及何時(shí)使用“責(zé)任鏈”設(shè)計(jì)模式。
翻譯自: https://www.javacodegeeks.com/2019/09/chain-of-responsibility-design-pattern-in-java.html
總結(jié)
以上是生活随笔為你收集整理的Java中的责任链设计模式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: moxy json介绍_使用MOXy 2
- 下一篇: 小米9手机什么时候上市(小米九手机上市时