這篇文章主要介紹“web設(shè)計(jì)模式的責(zé)任鏈模式有哪些優(yōu)缺點(diǎn)”,在日常操作中,相信很多人在web設(shè)計(jì)模式的責(zé)任鏈模式有哪些優(yōu)缺點(diǎn)問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”web設(shè)計(jì)模式的責(zé)任鏈模式有哪些優(yōu)缺點(diǎn)”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比雙灤網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式雙灤網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋雙灤地區(qū)。費(fèi)用合理售后完善,10余年實(shí)體公司更值得信賴。
客戶端發(fā)出一個(gè)請(qǐng)求,鏈上的對(duì)象都有機(jī)會(huì)來(lái)處理這一請(qǐng)求,而客戶端不需要知道誰(shuí)是具體的處理對(duì)象。這樣就實(shí)現(xiàn)了請(qǐng)求者和接受者之間的解耦,并且在客戶端可以實(shí)現(xiàn)動(dòng)態(tài)的組合職責(zé)鏈。使編程更有靈活性。
有多個(gè)對(duì)象共同對(duì)一個(gè)任務(wù)進(jìn)行處理。
些對(duì)象使用鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu),形成一個(gè)鏈,每個(gè)對(duì)象知道自己的下一個(gè)對(duì)象。
一個(gè)對(duì)象對(duì)任務(wù)進(jìn)行處理,可以添加一些操作后將對(duì)象傳遞個(gè)下一個(gè)任務(wù)。也可以在此對(duì)象上結(jié)束任務(wù)的處理,并結(jié)束任務(wù)。
客戶端負(fù)責(zé)組裝鏈?zhǔn)浇Y(jié)構(gòu),但是客戶端不需要關(guān)心最終是誰(shuí)來(lái)處理了任務(wù)。
抽象處理者(Handler)角色:定義出一個(gè)處理請(qǐng)求的接口。如果需要,接口可以定義 出一個(gè)方法以設(shè)定和返回對(duì)下家的引用。這個(gè)角色通常由一個(gè)Java抽象類或者Java接口實(shí)現(xiàn)。
具體處理者(ConcreteHandler)角色:具體處理者接到請(qǐng)求后,可以選擇將請(qǐng)求處理掉,或者將請(qǐng)求傳給下家。
優(yōu)點(diǎn): 職責(zé)鏈模式的最主要功能就是:動(dòng)態(tài)組合,請(qǐng)求者和接受者解耦。 請(qǐng)求者和接受者松散耦合:請(qǐng)求者不需要知道接受者,也不需要知道如何處理。每個(gè)職責(zé)對(duì)象只負(fù)責(zé)自己的職責(zé)范圍,其他的交給后繼者。各個(gè)組件間完全解耦。 動(dòng)態(tài)組合職責(zé):職責(zé)鏈模式會(huì)把功能分散到單獨(dú)的職責(zé)對(duì)象中,然后在使用時(shí)動(dòng)態(tài)的組合形成鏈,從而可以靈活的分配職責(zé)對(duì)象,也可以靈活的添加改變對(duì)象職責(zé)。 缺點(diǎn): 產(chǎn)生很多細(xì)粒度的對(duì)象:因?yàn)楣δ芴幚矶挤稚⒌搅藛为?dú)的職責(zé)對(duì)象中,每個(gè)對(duì)象功能單一,要把整個(gè)流程處理完,需要很多的職責(zé)對(duì)象,會(huì)產(chǎn)生大量的細(xì)粒度職責(zé)對(duì)象。 不一定能處理:每個(gè)職責(zé)對(duì)象都只負(fù)責(zé)自己的部分,這樣就可以出現(xiàn)某個(gè)請(qǐng)求,即使把整個(gè)鏈走完,都沒(méi)有職責(zé)對(duì)象處理它。這就需要提供默認(rèn)處理,并且注意構(gòu)造鏈的有效性。
多條件流程判斷 權(quán)限控制
ERP系統(tǒng) 流程審批 總經(jīng)理、人事經(jīng)理、項(xiàng)目經(jīng)理
Java過(guò)濾器的底層實(shí)現(xiàn)Filter 比如:在Java過(guò)濾器中客戶端發(fā)送請(qǐng)求到服務(wù)器端,過(guò)濾會(huì)經(jīng)過(guò)參數(shù)過(guò)濾、session過(guò)濾、表單過(guò)濾、隱藏過(guò)濾、檢測(cè)請(qǐng)求頭過(guò)濾
在網(wǎng)關(guān)作為微服務(wù)程序的入口,攔截客戶端所有的請(qǐng)求實(shí)現(xiàn)權(quán)限控制 ,比如先判斷Api接口限流、黑名單、用戶會(huì)話、參數(shù)過(guò)濾。 Api接口限流→黑名單攔截→用戶會(huì)話→參數(shù)過(guò)濾
public abstract class GatewayHandler { /** * 下一個(gè)handler */ protected GatewayHandler nextGatewayHandler; /** * 實(shí)現(xiàn)的handler 處理方案 強(qiáng)制必須實(shí)現(xiàn) */ public abstract void service(); public void setNextGatewayHandler(GatewayHandler nextGatewayHandler) { this.nextGatewayHandler = nextGatewayHandler; } /** *執(zhí)行下一個(gè)handler */ protected void nextService() { if (nextGatewayHandler != null) { nextGatewayHandler.service();// 指向下一關(guān)黑名單 } } }
@Component public class CurrentLimitHandler extends GatewayHandler { @Override public void service() { System.out.println("第一關(guān)網(wǎng)關(guān)限流判斷...."); nextService(); } } @Component public class BlacklistHandler extends GatewayHandler { @Override public void service() { System.out.println("第二關(guān)黑名單攔截判斷...."); nextService(); } } @Component public class ConversationHandler extends GatewayHandler { @Override public void service() { System.out.println("第三關(guān)用戶會(huì)話攔截判斷...."); nextService(); } }
CREATE TABLE `gateway_handler` ( `ID` int(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵ID', `handler_name` varchar(32) DEFAULT NULL COMMENT 'handler名稱', `handler_id` varchar(32) DEFAULT NULL COMMENT 'handler主鍵id', `prev_handler_id` varchar(32) DEFAULT NULL, `next_handler_id` varchar(32) DEFAULT NULL COMMENT '下一個(gè)handler', PRIMARY KEY (`ID`) ) ENGINE=InnoDB AUTO_INCREMENT=19 DEFAULT CHARSET=utf8 COMMENT='權(quán)限表'; -- ---------------------------- -- Records of gateway_handler -- ---------------------------- INSERT INTO `gateway_handler` VALUES ('16', 'Api接口限流', 'currentLimitHandler', null, 'blacklistHandler'); INSERT INTO `gateway_handler` VALUES ('17', '黑名單攔截', 'blacklistHandler', 'currentLimitHandler', 'conversationHandler'); INSERT INTO `gateway_handler` VALUES ('18', '會(huì)話驗(yàn)證', 'conversationHandler', 'blacklistHandler', null);
@Service public class GatewayHandlerService { @Autowired private GatewayHandlerMapper gatewayHandlerMapper; private GatewayHandler firstGatewayHandler; /** * 獲取數(shù)據(jù)庫(kù)第一個(gè)handeler封裝 * * @return */ public GatewayHandler getFirstGatewayHandler() { if (firstGatewayHandler != null) { return firstGatewayHandler; } // 1.從數(shù)據(jù)庫(kù)中查詢地址hanlder GatewayHandlerEntity firstGatewayHandlerEntity = gatewayHandlerMapper.getFirstGatewayHandler(); if (firstGatewayHandlerEntity == null) { return null; } // 2.獲取springboot注入容器id String handlerId = firstGatewayHandlerEntity.getHandlerId(); GatewayHandler firstGatewayHandler = SpringUtils.getBean(handlerId, GatewayHandler.class); // 3.獲取下一個(gè)handler容器beanid String nextHandlerId = firstGatewayHandlerEntity.getNextHandlerId(); // 4. 記錄當(dāng)前循環(huán)hanlder對(duì)象 GatewayHandler tempGatewayHandler = firstGatewayHandler; while (!StringUtils.isEmpty(nextHandlerId)) { // 5.從springboot容器獲取下一個(gè)handerl對(duì)象 GatewayHandler nextGatewayHandler = SpringUtils.getBean(nextHandlerId, GatewayHandler.class); tempGatewayHandler.setNextGatewayHandler(nextGatewayHandler); // 6.設(shè)置下一個(gè)nextHandlerId GatewayHandlerEntity nextGatewayHandlerEntity = gatewayHandlerMapper.getByHandler(nextHandlerId); if (nextGatewayHandlerEntity == null) { break; } nextHandlerId = nextGatewayHandlerEntity.getNextHandlerId(); tempGatewayHandler = nextGatewayHandler; } this.firstGatewayHandler = firstGatewayHandler; return firstGatewayHandler; } }
public interface GatewayHandlerMapper { /** * 獲取第一個(gè)GatewayHandler * * @return */ @Select("SELECT handler_name AS handlerName,handler_id AS handlerid ,prev_handler_id AS prevhandlerid ,next_handler_id AS nexthandlerid FROM gateway_handler WHERE prev_handler_id is null;;") public GatewayHandlerEntity getFirstGatewayHandler(); @Select("SELECT handler_name AS handlerName,handler_id AS handlerid ,prev_handler_id AS prevhandlerid ,next_handler_id AS nexthandlerid FROM gateway_handler WHERE handler_id=#{handlerId}") public GatewayHandlerEntity getByHandler(String handlerId); } @Data public class GatewayHandlerEntity implements Serializable, Cloneable { /** 主鍵ID */ private Integer id; /** handler名稱 */ private String handlerName; /** handler主鍵id */ private String handlerId; /** 下一個(gè)handler */ private String nextHandlerId; }
@RestController public class HandlerController { @Autowired private GatewayHandlerService gatewayHandlerService; @RequestMapping("/client") public String client() { GatewayHandler firstGatewayHandler = gatewayHandlerService.getFirstGatewayHandler(); firstGatewayHandler.service(); return "success"; } }
本文參考:螞蟻課堂:http://www.mayikt.com
到此,關(guān)于“web設(shè)計(jì)模式的責(zé)任鏈模式有哪些優(yōu)缺點(diǎn)”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
分享標(biāo)題:web設(shè)計(jì)模式的責(zé)任鏈模式有哪些優(yōu)缺點(diǎn)
本文路徑:http://chinadenli.net/article34/gohose.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、搜索引擎優(yōu)化、響應(yīng)式網(wǎng)站、微信公眾號(hào)、網(wǎng)站收錄、虛擬主機(jī)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)