이 메소드는 더 간단하지만 구성이 쉽지 않습니다.
참고: 스프링 컨테이너로 스캔해야 합니다.
필터 인터페이스를 구현하기 위한 클래스를 생성합니다.
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
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 구현에 대한 시간 소모적인 예제 비교 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!