日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java责任链设计模式_Java中的责任链设计模式

發(fā)布時間:2023/12/3 java 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java责任链设计模式_Java中的责任链设计模式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

java責任鏈設計模式

在本教程中,我們將學習如何在Java中實現責任鏈模式。

責任鏈設計模式涉及到擁有一系列負責處理請求的對象鏈。 當客戶端發(fā)送請求時,第一個處理程序將嘗試處理該請求。 如果可以處理,則請求處理在此結束。 但是,如果處理程序無法處理用戶請求,則它將轉到鏈中的下一個處理程序。 該過程將繼續(xù)進行,直到鏈中的任何一個處理程序成功處理請求或鏈結束為止。 如果整個鏈條都無法處理該請求,則意味著該請求仍然無法滿足。

為什么要使用責任鏈?

責任鏈是我們軟件行業(yè)中非常重要的設計模式。 它具有以下優(yōu)點:

  • 由于用戶不需要關心哪個對象將處理其請求,因此它促進了用戶與系統之間的松散耦合。
  • Java異常處理機制也利用了這種模式。 如果找不到合適的catch塊,則將請求委托給調用方方法進行處理,直到找到合適的處理程序為止
  • 通過讓請求通過一系列過濾器,該模式還可以找到其在過濾用戶請求中的應用

UML表示形式:

責任鏈模式的UML表示類似于:

在這里,我們具有以下類型的對象:

  • 客戶:發(fā)出用戶請求的代碼
  • 處理程序: 抽象超類或定義請求處理程序方法的接口
  • 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中的责任链设计模式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。