ホームページ  >  記事  >  Java  >  フィルター インターセプターの SpringBoot 実装の時間のかかる例の比較分析

フィルター インターセプターの SpringBoot 実装の時間のかかる例の比較分析

WBOY
WBOY転載
2023-05-12 09:43:131667ブラウズ

Filter メソッド

このメソッドは単純ですが、あまり構成可能ではありません

注: Spring コンテナにスキャンする必要があります

次のクラスを作成しますフィルタ インターフェイスを実装します

  • init: このメソッドはフィルタ オブジェクトを初期化するメソッドです。コンテナがフィルタ オブジェクトを初期化した後に 1 回だけ呼び出されます。パラメータ 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);
    }
}

結果

フィルター インターセプターの SpringBoot 実装の時間のかかる例の比較分析

概要

1. フィルターは、一般的な関数を実装し、コードの冗長性を減らすために使用されます。保守性の向上;

2. 複数のリソースに対して 1 つのフィルターを構成できます (コーディング フィルター);

3. 順次呼び出される構成に従って、1 つのリソースに複数のフィルターを構成することもできます。

インターセプターのメソッド

理解できない場合は、最初に概要を読んでから、もう一度読んでください

インターセプターの概要

もう何も言わずにそのまま進んでください。コードに

インターセプタを作成します

/**
 * 拦截器: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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。