[Spring Boot] 2) Springboot OncePerRequestFilter 와 GenericFilterBean의 차이

Spring/Filter 2021. 4. 30. 10:42

앞에 1부에서 간단히 springboot에서 Filter 등록하고 사용하는 방법에 대해 알아 봤다. 

앞의 예제에서 보면 아래와 같은 흐름으로 동작을 하는것을 알 수있다. 

 

 

 

1) api 1 호출 request

2) first , second filter 

3) api1 controller 요청받음. 요청 처리 후 , api2로 sendRedirct 함.

4) 다시 first , second filter를 탐

5) api2 controller 요청받음. 요청 처리후 response

 

이런 흐름을 보여주고 있다. 여기서 문제점은 실제 요청자는 요청을 한번만 했을뿐인데 

흐름상 요청을 두번한것과 같은 형태가 되어 있다. 

 

first 와 second 의 필터가 어떤것이냐 하는 상황에 따라 다르겠지만 간단히 인증처리를 하는 

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

filter라고 생각을 한다면 요청자의 요청에 대한 인증처리는 한번만 하면 되는것인데 

 

흐름상 무조건 두번을 또는 redirect를 몇번을 시키냐에 따라 여러번 인증처리 또는 불필요한 처리를 반복하게 된다.

이런 문제를 해결하기 위해 OncePerRequestFilter 라는 것이 나왔다. 

 

OncePerRequestFilter의 샘플소스는 아래와 같이 간단하게 만들 수 있다.

package com.devracoon.test.filter;

import lombok.extern.slf4j.Slf4j;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import org.springframework.web.filter.GenericFilterBean;
import org.springframework.web.filter.OncePerRequestFilter;

import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@Slf4j
@Order(0)
@Component
public class FirstFilter extends OncePerRequestFilter {

    @Override
    protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {
        log.info("first filter");

        filterChain.doFilter(request , response);
    }
}

 

package com.devracoon.test.filter;

import lombok.extern.slf4j.Slf4j;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import org.springframework.web.filter.GenericFilterBean;
import org.springframework.web.filter.OncePerRequestFilter;

import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@Slf4j
@Order(1)
@Component
public class SecondFilter extends OncePerRequestFilter {
    @Override
    protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {
        log.info("second filter");
        filterChain.doFilter(request , response);
    }
}
package com.devracoon.test.controller;

import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.RequestDispatcher;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@RestController
@RequestMapping("/test/api")
public class TestRestAPI {

    @RequestMapping("{name}")
    public TestDTO testapi(HttpServletRequest request , HttpServletResponse response,
                           @PathVariable("name") String name) throws Exception{
        response.sendRedirect(request.getContextPath() + "/test/api/forward/" + name);

        return TestDTO.builder().id("1").name(name).build();
    }

    @RequestMapping("/forward/{name}")
    public TestDTO forwardTestApi(@PathVariable("name") String name){

        return TestDTO.builder().id("1").name(name).build();
    }

}

위의 샘플 소스로 테스트 호출을 해보면 아래결과 처럼 filter를 한번만 타는것을 확인 할 수 있다.

 

 

 [출처] https://dev-racoon.tistory.com/34

 

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
424 [java, spring] Spring에서 request와 response를 JSON format 으로 한번에 로깅하기 file 졸리운_곰 2021.06.18 178
» [Spring Boot] 2) Springboot OncePerRequestFilter 와 GenericFilterBean의 차이 file 졸리운_곰 2021.06.18 21
422 [Spring boot] [Spring boot] Spring Boot servlet filter 사용하기 졸리운_곰 2021.06.18 17
421 [SpringBoot] Filter(필터) OncePerRequestFilter간단히 사용하기 file 졸리운_곰 2021.06.18 65
420 [Spring boot] Spring boot 에서 Filter 사용하기 졸리운_곰 2021.06.18 18
419 [Spring Boot] 스프링 부트에 필터를 '조심해서' 사용하는 두 가지 방법 졸리운_곰 2021.06.18 140
418 [Java 자료구조] [Java] 문자열의 첫 글자 제거 졸리운_곰 2021.05.24 406
417 [Java 자료구조] [java] 특정 문자열 사이의 문자열 추출하기, 정규식 졸리운_곰 2021.05.24 1875
416 [Java 자료구조] [JAVA] Java언어로 JSON 생성, 파싱 예제 file 졸리운_곰 2021.05.17 19
415 이클립스에서 java 버전 변경 file 졸리운_곰 2021.04.29 33
414 [Java 자료구조] [Java] Immutable Class (불변 클래스) file 졸리운_곰 2021.03.07 26
413 [Java 자료구조] 불변 객체란? Java Immutable Object file 졸리운_곰 2021.03.07 48
412 [Java 자료구조] [Java] Immutable Object(불변객체) 졸리운_곰 2021.03.07 44
411 [java 자료구조] Oracle + Mybatis 환경에서의 Date 다루기 졸리운_곰 2021.02.25 57
410 Java JSON library Jackson Date Date Json 시리얼라이즈/디씨리얼라이즈 file 졸리운_곰 2021.02.25 28
409 [Java, JSON, jackson] Ignoring new fields on JSON objects using Jackson 졸리운_곰 2021.02.19 16
408 [Java] [Jackson] JsonInclude 속성에 대해 알아보자. 졸리운_곰 2021.02.03 592
407 [java] [jackson] Map - JSON간 변환 졸리운_곰 2021.02.02 41
406 [java] [자료구조] Remove null values from json using jackson 졸리운_곰 2021.02.02 78
405 Eclipse RAP Tutorial for Beginners - Workbench Application (OLD) file 졸리운_곰 2021.01.30 66
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED