>  기사  >  Java  >  필터 인터셉터의 SpringBoot 구현에 대한 시간 소모적인 예제 비교 분석

필터 인터셉터의 SpringBoot 구현에 대한 시간 소모적인 예제 비교 분석

WBOY
WBOY앞으로
2023-05-12 09:43:131667검색

Filter 메소드

이 메소드는 더 간단하지만 구성이 쉽지 않습니다.

참고: 스프링 컨테이너로 스캔해야 합니다.

필터 인터페이스를 구현하기 위한 클래스를 생성합니다.

  • init: 이 메소드는 필터를 위한 것입니다. 객체 초기화 메소드는 컨테이너가 필터 객체를 초기화한 후에만 호출됩니다. FilterConfig 매개변수는 필터의 초기화 매개변수를 얻을 수 있습니다.

  • doFilter: 요청 및 응답을 수행할 수 있습니다. <u>预处理</u>其中FilterChain可以将处理后的요청 및 응답 객체가 필터 체인에 전달됩니다. 자원.

  • destroy(): 이 메서드는 컨테이너가 객체를 파괴하기 전에 호출됩니다.

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;

@Component
public class LogFilter implements Filter {

    private static final Logger LOG = LoggerFactory.getLogger(LogFilter.class);

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        // 打印请求信息
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        LOG.info("------------- LogFilter 开始 -------------");
        LOG.info("请求地址: {} {}", request.getRequestURL().toString(), request.getMethod());
        LOG.info("远程地址: {}", request.getRemoteAddr());

        long startTime = System.currentTimeMillis();
        filterChain.doFilter(servletRequest, servletResponse);
        LOG.info("------------- LogFilter 结束 耗时:{} ms -------------", System.currentTimeMillis() - startTime);
    }
}

Results

필터 인터셉터의 SpringBoot 구현에 대한 시간 소모적인 예제 비교 분석

Summary

1. 필터는 공통 기능을 구현하고, 코드 중복을 줄이고, 유지 관리성을 향상시키는 데 사용됩니다.

2. 필터는 여러 리소스에서 사용하도록 구성할 수 있습니다. ;

3. 구성 순서대로 호출되는 여러 필터를 사용하여 리소스를 구성할 수도 있습니다.

인셉터 사용법

이해가 안되면 소개를 먼저 읽고 다시 오세요

인터셉터 소개

더 이상 말은 하지 말고 코드대로 가세요

인셉터 만들기

/**
 * 拦截器:Spring框架特有的,常用于登录校验,权限校验,请求日志打印 /login
 * @author : look-word
 * 2022-06-26 13:55
 **/
@Component
public class LogInterceptor implements HandlerInterceptor {
    private static final Logger LOG = LoggerFactory.getLogger(LogInterceptor.class);

        
    @Override
     public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
         // 打印请求信息
         LOG.info("------------- LogInterceptor 开始 -------------");
         LOG.info("请求地址: {} {}", request.getRequestURL().toString(), request.getMethod());
         LOG.info("远程地址: {}", request.getRemoteAddr());

         long startTime = System.currentTimeMillis();
         request.setAttribute("requestStartTime", startTime);
         return true;
     }

     @Override
     public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
         long startTime = (Long) request.getAttribute("requestStartTime");
         LOG.info("------------- LogInterceptor 结束 耗时:{} ms -------------", System.currentTimeMillis() - startTime);
     }
}

인터셉터 등록

우리 인터셉터가 인터셉터 체인에 등록되었습니다

/**
 * @author : look-word
 * 2022-06-26 14:03
 **/
@Configuration
public class SpringMvcConfig implements WebMvcConfigurer {

    @Resource
    private LogInterceptor logInterceptor;
    /**
     * 注册拦截器
     * @param registry
     */
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry
                .addInterceptor(logInterceptor)
                .addPathPatterns("/**")// 对那些接口拦截
                .excludePathPatterns("/login");// 对哪些接机口放行
        WebMvcConfigurer.super.addInterceptors(registry);
    }
}

테스트 결과

필터 인터셉터의 SpringBoot 구현에 대한 시간 소모적인 예제 비교 분석

위 내용은 필터 인터셉터의 SpringBoot 구현에 대한 시간 소모적인 예제 비교 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제