このメソッドは単純ですが、あまり構成可能ではありません
注: 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); } }
結果
概要
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 サイトの他の関連記事を参照してください。