溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Spring Cloud Zuul添加過濾器過程解析

發(fā)布時(shí)間:2020-09-05 12:11:14 來源:腳本之家 閱讀:390 作者:SongAlone 欄目:編程語言

這篇文章主要介紹了Spring Cloud Zuul添加過濾器過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

Zuul作為網(wǎng)關(guān)的其中一個(gè)重要功能,就是實(shí)現(xiàn)請求的鑒權(quán)。而這個(gè)動作我們往往是通過Zuul提供的過濾器來實(shí)現(xiàn)的。

一、過濾器方法的作用

想要使用Zuul實(shí)現(xiàn)過濾功能,我們需要自定義一個(gè)類繼承ZuulFilter類,并實(shí)現(xiàn)其中的四個(gè)方法,我們先看一下這四個(gè)方法的作用是什么

public class MyFilter extends ZuulFilter {
  /**
   * filterType:返回字符串,代表過濾器的類型。包含以下4種:
   * -- pre:請求在被路由之前執(zhí)行
   * -- route:在路由請求時(shí)調(diào)用
   * -- post:在route和errror過濾器之后調(diào)用
   * -- error:處理請求時(shí)發(fā)生錯(cuò)誤調(diào)用
   * @return 返回以上四個(gè)類型的名稱
   */
  @Override
  public String filterType() {
    return null;
  }

  /**
   * filterOrder:通過返回的int值來定義過濾器的執(zhí)行順序,數(shù)字越小優(yōu)先級越高。
   * @return
   */
  @Override
  public int filterOrder() {
    return 0;
  }

  /**
   * shouldFilter:返回一個(gè)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)){
      //過濾該請求,不對其進(jìn)行路由
      context.setSendZuulResponse(false);
      //設(shè)置響應(yīng)碼401
      context.setResponseStatusCode(HttpStatus.SC_UNAUTHORIZED);
      //設(shè)置響應(yīng)體
      context.setResponseBody("request error....");
    }
    // 校驗(yàn)通過,把登陸信息放入上下文信息,繼續(xù)向后執(zhí)行
    context.set("username",username);
    return null;
  }
}

沒添加過濾功能之前是這樣的 ↓,無論加不加username都可以得到數(shù)據(jù)

Spring Cloud Zuul添加過濾器過程解析

Spring Cloud Zuul添加過濾器過程解析

添加了過濾功能之后是這樣的 ↓,只有加了username才能訪問

Spring Cloud Zuul添加過濾器過程解析

Spring Cloud Zuul添加過濾器過程解析

F12打開控制臺,發(fā)現(xiàn)響應(yīng)了401

Spring Cloud Zuul添加過濾器過程解析

三、過濾器執(zhí)行的聲明周期

過濾器執(zhí)行的聲明周期

Spring Cloud Zuul添加過濾器過程解析

正常流程:

請求到達(dá)首先會經(jīng)過pre類型過濾器,而后到達(dá)route類型,進(jìn)行路由,請求就到達(dá)真正的服務(wù)提供者,執(zhí)行請求,返回結(jié)果后,會到達(dá)post過濾器。而后返回響應(yīng)。

異常流程:

整個(gè)過程中,pre或者route過濾器出現(xiàn)異常,都會直接進(jìn)入error過濾器,在error處理完畢后,會將請求交給POST過濾器,最后返回給用戶。

如果是error過濾器自己出現(xiàn)異常,最終也會進(jìn)入POST過濾器,將最終結(jié)果返回給請求客戶端。

如果是POST過濾器出現(xiàn)異常,會跳轉(zhuǎn)到error過濾器,但是與pre和route不同的是,請求不會再到達(dá)POST過濾器了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI