SpringBoot之Filter

转载自:

Filter介绍

Filter 过滤器主要是用来过滤用户请求的,它允许我们对用户请求进行前置处理和后置处理,比如实现 URL 级别的权限控制,过滤非法请求等等。Filter 过滤器是面向切面编程 — AOP具体实现

Filter 是依赖于 Servlet 容器,Filter 接口就在 Servlet 包下面,属于 Servlet 规范的一部分。所以,很多时候我们也称其为“增强版 Servlet”。

如果我们需要自定义 Filter 的话非常简单,只需要实现 javax.Servlet.Filter 接口,然后重写里面的三个方法即可!

Filter.java

package javax.servlet;

import java.io.IOException;

public interface Filter {
  
   //初始化过滤器后执行的操作
    default void init(FilterConfig filterConfig) throws ServletException {
    }
   // 对请求进行过滤
    void doFilter(ServletRequest var1, ServletResponse var2, FilterChain var3) throws IOException, ServletException;
   // 销毁过滤器后执行的操作,主要用户对某些资源的回收
    default void destroy() {
    }
}

Filter 是如何实现拦截的?

Filter 接口中有一个叫做 doFilter 的方法,这个方法实现了对用户请求的过滤。具体流程大体是这样的:

  1. 用户发送请求到 web 服务器,请求会先到过滤器;
  2. 过滤器会对请求进行一些处理比如过滤请求的参数、修改返回给客户端的 response 的内容、判断是否让用户访问该接口等等。
  3. 用户请求响应完毕
  4. 进行一些自己想要的其他操作

如何自定义 Filter

@WebFilter 注解

@WebFilter 用于将一个类声明为过滤器,该注解将会在部署时被容器处理,容器将根据具体的属性配置将相应的类部署为过滤器。该注解具有下表给出的一些常用属性 ( 以下所有属性均为可选属性,但是 value、urlPatterns、servletNames 三者必需至少包含一个,且 value 和 urlPatterns 不能共存,如果同时指定,通常忽略 value 的取值 )

示例

https://gitee.com/mikeLv01/security-filter-demo.git

结果示意图:

161

发布了18 篇原创文章 · 获赞 0 · 访问量 416

猜你喜欢

转载自blog.csdn.net/mikelv01/article/details/105344437
今日推荐