java责任链设计模式_Java中的责任链设计模式
java責任鏈設計模式
在本教程中,我們將學習如何在Java中實現責任鏈模式。
責任鏈設計模式涉及到擁有一系列負責處理請求的對象鏈。 當客戶端發送請求時,第一個處理程序將嘗試處理該請求。 如果可以處理,則請求處理在此結束。 但是,如果處理程序無法處理用戶請求,則它將轉到鏈中的下一個處理程序。 該過程將繼續進行,直到鏈中的任何一個處理程序成功處理請求或鏈結束為止。 如果整個鏈條都無法處理該請求,則意味著該請求仍然無法滿足。
為什么要使用責任鏈?
責任鏈是我們軟件行業中非常重要的設計模式。 它具有以下優點:
- 由于用戶不需要關心哪個對象將處理其請求,因此它促進了用戶與系統之間的松散耦合。
- Java異常處理機制也利用了這種模式。 如果找不到合適的catch塊,則將請求委托給調用方方法進行處理,直到找到合適的處理程序為止
- 通過讓請求通過一系列過濾器,該模式還可以找到其在過濾用戶請求中的應用
UML表示形式:
責任鏈模式的UML表示類似于:
在這里,我們具有以下類型的對象:
- 客戶:發出用戶請求的代碼
- 處理程序: 抽象超類或定義請求處理程序方法的接口
- ConcreteHandler: Handler的實現類
處理程序對象在鏈中從一個連接到另一個。 另外, 每個具體處理程序都以其自己獨特的方式處理請求。
定義抽象處理程序:
讓我們使用責任鏈實現請求過濾邏輯。
首先,我們將定義一個抽象的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; } }定義具體處理程序:
現在,讓我們定義鏈中的第一個過濾器類,它將阻止來自可疑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) { ... } }同樣,讓我們??定義鏈中的第二個過濾器,它將阻止未授權的請求:
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) { ... } }最后一個過濾器將識別和阻止嘗試登錄次數超出的用戶:
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) { ... } }調用鏈:
最后,是時候將它們編織成鏈了:
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);在這里,每個用戶請求將遵循以下過濾鏈:
這些過濾器標準之一一旦匹配,匹配的過濾器就會過濾掉該用戶請求。 這也意味著剩余的鏈將被跳過。
結論:
在本教程中,我們學習了如何以及何時使用責任鏈設計模式。
翻譯自: https://www.javacodegeeks.com/2019/09/chain-of-responsibility-design-pattern-in-java.html
java責任鏈設計模式
總結
以上是生活随笔為你收集整理的java责任链设计模式_Java中的责任链设计模式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 金鱼身上发黑能恢复吗(金鱼身上的黑斑怎么
- 下一篇: 数码宝贝电脑版大全(数码宝贝游戏电脑版)