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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > java >内容正文

java

Java中的责任链设计模式

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

在本教程中,我們將學(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)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。