Spring Cloud Zuul 필터 추가 프로 세 스 분석

이 글 은 주로 Spring Cloud Zuul 에 필 터 를 추가 하 는 과정 을 소개 합 니 다.이 글 은 예시 코드 를 통 해 매우 상세 하 게 소개 되 어 있 으 며 여러분 의 학습 이나 업무 에 대해 어느 정도 참고 학습 가치 가 있 으 므 로 필요 한 분 들 은 참고 하 시기 바 랍 니 다.
Zuul 은 게 이 트 웨 이 의 중요 한 기능 중 하나 로 서 요청 의 감 권 을 실현 하 는 것 이다.이 동작 은 Zuul 이 제공 하 는 필 터 를 통 해 이 루어 집 니 다.
1.필터 방법의 역할
Zuul 을 사용 하여 필터 기능 을 실현 하려 면 Zuul Filter 류 를 계승 하고 그 중의 네 가지 방법 을 사용자 정의 해 야 합 니 다.이 네 가지 방법의 역할 이 무엇 인지 먼저 살 펴 보 겠 습 니 다.

public class MyFilter extends ZuulFilter {
  /**
   * filterType:     ,        。    4 :
   * -- pre:          
   * -- route:        
   * -- post: route errror       
   * -- error:           
   * @return            
   */
  @Override
  public String filterType() {
    return null;
  }

  /**
   * filterOrder:     int            ,         。
   * @return
   */
  @Override
  public int filterOrder() {
    return 0;
  }

  /**
   * shouldFilter:    Boolean ,            。  true  ,  false   。
   * @return
   */
  @Override
  public boolean shouldFilter() {
    return false;
  }

  /**
   * run:            。
   * @return
   * @throws ZuulException
   */
  @Override
  public Object run() throws ZuulException {
    return null;
  }
}
2.사용자 정의 필터
프 리 스타일 로 보 여 드릴 게 요.

@Component
public class LoginFilter extends ZuulFilter {

  //     pre route post error
  @Override
  public String filterType() {
    return "pre";
  }

  //     ,         
  @Override
  public int filterOrder() {
    return 10;
  }

  //    run  
  @Override
  public boolean shouldFilter() {
    return true;
  }

  //      
  @Override
  public Object run() throws ZuulException {
    //  zuul        
    RequestContext context = RequestContext.getCurrentContext();
    //  request  
    HttpServletRequest request = context.getRequest();
    //      
    String token = request.getParameter("username");
    //  
    if (StringUtils.isBlank(username)){
      //     ,       
      context.setSendZuulResponse(false);
      //     401
      context.setResponseStatusCode(HttpStatus.SC_UNAUTHORIZED);
      //     
      context.setResponseBody("request error....");
    }
    //     ,            ,      
    context.set("username",username);
    return null;
  }
}
필터 기능 을 추가 하지 않 았 을 때 는 이 렇 습 니 다↓,username 을 추가 하 든 말 든 데 이 터 를 얻 을 수 있 습 니 다.


필터 기능 이 추 가 된 후 에는 이렇게↓합 니 다.username 을 추가 해 야 접근 할 수 있 습 니 다.


F12 콘 솔 을 열 었 더 니 응답 이 401 이 었 습 니 다.

3.필터 가 실행 하 는 성명 주기
필터 실행 주기

정상 흐름:
요청 이 도착 하면 우선 pre 형식 필 터 를 거 쳐 route 형식 에 도착 하고 경로 가 진행 되 며 요청 이 실제 서비스 제공 자 에 게 도착 하여 요청 을 수행 하고 결 과 를 되 돌려 주면 post 필터 에 도착 합 니 다.그리고 응답 을 되 돌려 줍 니 다.
이상 흐름:
전체 과정 에서 pre 나 route 필터 에 이상 이 생기 면 error 필터 에 직접 들 어가 error 처리 가 끝 난 후에 POST 필터 에 요청 을 건 네 주 고 마지막 으로 사용자 에 게 돌아 갑 니 다.
error 필터 가 스스로 이상 이 생기 면 POST 필터 에 들 어가 최종 결 과 를 요청 클 라 이언 트 에 게 되 돌려 줍 니 다.
POST 필터 에 이상 이 생기 면 error 필터 로 넘 어 갑 니 다.그러나 pre 와 route 와 달리 POST 필터 에 더 이상 도달 하지 않 기 를 요청 합 니 다.
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기