Spring Cloud Zuul添加過濾器過程解析
這篇文章主要介紹了Spring Cloud Zuul添加過濾器過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
Zuul作為網(wǎng)關(guān)的其中一個重要功能,就是實現(xiàn)請求的鑒權(quán)。而這個動作我們往往是通過Zuul提供的過濾器來實現(xiàn)的。
一、過濾器方法的作用
想要使用Zuul實現(xiàn)過濾功能,我們需要自定義一個類繼承ZuulFilter類,并實現(xiàn)其中的四個方法,我們先看一下這四個方法的作用是什么
public class MyFilter extends ZuulFilter { /** * filterType:返回字符串,代表過濾器的類型。包含以下4種: * -- pre:請求在被路由之前執(zhí)行 * -- route:在路由請求時調(diào)用 * -- post:在route和errror過濾器之后調(diào)用 * -- error:處理請求時發(fā)生錯誤調(diào)用 * @return 返回以上四個類型的名稱 */ @Override public String filterType() { return null; } /** * filterOrder:通過返回的int值來定義過濾器的執(zhí)行順序,數(shù)字越小優(yōu)先級越高。 * @return */ @Override public int filterOrder() { return 0; } /** * shouldFilter:返回一個Boolean值,判斷該過濾器是否需要執(zhí)行。返回true執(zhí)行,返回false不執(zhí)行。 * @return */ @Override public boolean shouldFilter() { return false; } /** * run:編寫過濾器的具體業(yè)務(wù)邏輯。 * @return * @throws ZuulException */ @Override public Object run() throws ZuulException { return null; } }
二、自定義過濾器
我這里以pre類型演示
@Component public class LoginFilter extends ZuulFilter { //過濾類型 pre route post error @Override public String filterType() { return "pre"; } //過濾優(yōu)先級,數(shù)字越小優(yōu)先級越高 @Override public int filterOrder() { return 10; } //是否執(zhí)行run方法 @Override public boolean shouldFilter() { return true; } //過濾邏輯代碼 @Override public Object run() throws ZuulException { //獲取zuul提供的上下文對象 RequestContext context = RequestContext.getCurrentContext(); //獲取request對象 HttpServletRequest request = context.getRequest(); //獲取請求參數(shù) String token = request.getParameter("username"); //判斷 if (StringUtils.isBlank(username)){ //過濾該請求,不對其進行路由 context.setSendZuulResponse(false); //設(shè)置響應(yīng)碼401 context.setResponseStatusCode(HttpStatus.SC_UNAUTHORIZED); //設(shè)置響應(yīng)體 context.setResponseBody("request error...."); } // 校驗通過,把登陸信息放入上下文信息,繼續(xù)向后執(zhí)行 context.set("username",username); return null; } }
沒添加過濾功能之前是這樣的 ↓,無論加不加username都可以得到數(shù)據(jù)
添加了過濾功能之后是這樣的 ↓,只有加了username才能訪問
F12打開控制臺,發(fā)現(xiàn)響應(yīng)了401
三、過濾器執(zhí)行的聲明周期
過濾器執(zhí)行的聲明周期
正常流程:
請求到達首先會經(jīng)過pre類型過濾器,而后到達route類型,進行路由,請求就到達真正的服務(wù)提供者,執(zhí)行請求,返回結(jié)果后,會到達post過濾器。而后返回響應(yīng)。
異常流程:
整個過程中,pre或者route過濾器出現(xiàn)異常,都會直接進入error過濾器,在error處理完畢后,會將請求交給POST過濾器,最后返回給用戶。
如果是error過濾器自己出現(xiàn)異常,最終也會進入POST過濾器,將最終結(jié)果返回給請求客戶端。
如果是POST過濾器出現(xiàn)異常,會跳轉(zhuǎn)到error過濾器,但是與pre和route不同的是,請求不會再到達POST過濾器了。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Mybatis?大數(shù)據(jù)量批量寫優(yōu)化的案例詳解
這篇文章主要介紹了Mybatis?大數(shù)據(jù)量批量寫優(yōu)化的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-05-05javafx tableview鼠標觸發(fā)更新屬性詳解
這篇文章主要為大家詳細介紹了javafx tableview鼠標觸發(fā)更新屬性的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08springboot動態(tài)定時任務(wù)的實現(xiàn)方法示例
這篇文章主要給大家介紹了關(guān)于springboot動態(tài)定時任務(wù)的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02Java讀取項目json文件并轉(zhuǎn)為JSON對象的操作
這篇文章主要介紹了Java讀取項目json文件并轉(zhuǎn)為JSON對象的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08解決SpringBoot jar包中的文件讀取問題實現(xiàn)
這篇文章主要介紹了解決SpringBoot jar包中的文件讀取問題實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-08-08