OncePerRequestFilter过滤器

过滤器在请求到达目标资源之前或响应返回客户端之前对请求或响应进行拦截和处理,OncePerRequestFilter过滤器逻辑在一次完整的HTTP请求中仅执行一次,即使请求在服务器内部经过了多次转发(forward)或包含多个资源请求。

OncePerRequestFilter的使用

public class DemoFilter extends OncePerRequestFilter {

@Override
protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {
String url = request.getRequestURI();
System.out.println("----->过滤器开始处理请求"+url);
long startTime = System.currentTimeMillis();
filterChain.doFilter(request,response);
long timeTaken = System.currentTimeMillis() - startTime;
System.out.println("<-----过滤器处理结束,url:"+url+"耗时:"+timeTaken);
}
}

注册OncePerRequestFilter
@Configuration
public class FilterConfig {

@Bean
public FilterRegistrationBean<DemoFilter> registrationBean(){
System.out.println("过滤器生成范围");
FilterRegistrationBean<DemoFilter> registrationBean = new FilterRegistrationBean<>();
registrationBean.setFilter(new DemoFilter());
//设置过滤器生成范围
registrationBean.addUrlPatterns("/*");
//过滤器名称
registrationBean.setName("demoFilter");
//设置优先级
registrationBean.setOrder(1);
return registrationBean;
}
}
posted @   客至在水一方  阅读(38)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示