๐Ÿ”ฎSpring

[Spring Boot] Spring Boot 2.6.2 Interceptor ์ถ”๊ฐ€

harry.93 2022. 1. 26. 22:22
๋ฐ˜์‘ํ˜•

1. Interceptor ์ƒ์„ฑ

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

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

@Component
public class defaultInterceptor implements HandlerInterceptor {
    private Logger logger = LoggerFactory.getLogger(this.getClass());

    /* ์ปจํŠธ๋กค๋Ÿฌ ์‹คํ–‰ ์ „ ์ˆ˜ํ–‰ */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        logger.info("[LOG] interceptor prehandle");
        return true;
    }

    /* ์ปจํŠธ๋กค๋Ÿฌ ์‹คํ–‰ ํ›„, ๋ทฐ ๋ Œ๋”๋ง ์ „ ์‹คํ–‰ */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
            ModelAndView modelAndView) throws Exception {
        logger.info("[LOG] interceptor postHandle");
    }

    /* ์ปจํŠธ๋กค๋Ÿฌ ์‹คํ–‰ ํ›„, ๋ทฐ ๋ Œ๋”๋ง ํ›„ ์‹คํ–‰ */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        logger.info("[LOG] interceptor afterCompletion");
    }

}

 

 

2. ์„ค์ • ์ ์šฉํ•˜๊ธฐ

import com.docker.bootsample.interceptor.defaultInterceptor;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

/* spring framework ์—์„œ Bean ์—์„œ ํ•˜๋˜ ์„ค์ •์„ java๋กœ ํ•˜๊ฒŒ ๋˜๋ฉฐ ์„ค์ •์„ ์ด ๊ณณ์—์„œ ํ•œ๋‹ค. */
@Configuration
public class MvcConfig implements WebMvcConfigurer {

    /* ์‹คํ–‰ ์‹œ, defaultInterceptor๋ฅผ ๊ฐ€์ ธ์™€ ์ฃผ์ž…ํ•˜์—ฌ ์‚ฌ์šฉ */
    @Autowired
    private defaultInterceptor defaulInterceptor;

    /* ์ธํ„ฐ์…‰ํ„ฐ ์ถ”๊ฐ€ํ•˜๋Š” ๋ฉ”์†Œ๋“œ */
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(defaulInterceptor) // ์ธํ„ฐ์…‰ํ„ฐ ์ถ”๊ฐ€
                .addPathPatterns("/**") // ์ ์šฉํ•  ํŒจํ„ด ์ถ”๊ฐ€
                .excludePathPatterns(); // ์ œ์™ธํ•  ํŒจํ„ด ์ถ”๊ฐ€
    }
}

 

728x90
๋ฐ˜์‘ํ˜•