溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

詳談springboot過濾器和攔截器的實現(xiàn)及區(qū)別

發(fā)布時間:2020-09-21 06:55:39 來源:腳本之家 閱讀:182 作者:tom和cat 欄目:編程語言

前言

springmvc中有兩種很普遍的AOP實現(xiàn):

1.過濾器(Filter)

2.攔截器(Interceptor)

本篇面對的是一些剛接觸springboot的人群

所以主要講解filter和interceptor的簡單實現(xiàn)和它們之間到底有什么區(qū)別

(一些復(fù)雜的功能我會之后發(fā)出文章,請記得關(guān)注)

Filter的簡單實現(xiàn)

字面意思:過濾器就是過濾的作用,在web開發(fā)中過濾一些我們指定的url

那么它能幫我們過濾什么呢?

那功能可就多了:

比如過攔截掉我們不需要的接口請求

修改請求(request)和響應(yīng)(response)內(nèi)容

完成CORS跨域請求等等

現(xiàn)在我們來實現(xiàn)一個簡單的過濾器:

可以新建一個filter包,隨著項目的擴大過濾器會越來越多

在這里我新建了一個TestFilter類,實現(xiàn)Filter接口

@Component
@WebFilter(urlPatterns = "/Blogs",filterName = "blosTest")
public class TestFilter implements Filter{}

我們一步步來

1.@Component就是把這個類注入到IOC容器中

2.@WebFilter(urlPatterns = "/Blogs",filterName = "blosTest")說明這是一個web過濾器,它攔截的url為/Blogs,過濾器名字為blogsTest

下面貼出實現(xiàn)接口之后的三個重構(gòu)方法:

@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;
    HttpServletResponse response = (HttpServletResponse) servletResponse;
    System.out.printf("過濾器實現(xiàn)");
    filterChain.doFilter(request,response);
  }
 
  @Override
  public void destroy() {
 
  }

初始化(init)和摧毀(destroy)方法一般不會用到,具體使用看下源碼便知

doFilter()是過濾器的核心

注意:在實現(xiàn)接口方法之后,我們要轉(zhuǎn)換request和response類型至HttpServlet,否則接下去的操作可能會報錯。

如果過濾通過,執(zhí)行filterChain.doFilter(request,response);

說明這個url已經(jīng)經(jīng)過了我們的Filter

可以看到,只需要一個類我們就實現(xiàn)了一個簡單的過濾器

當(dāng)然可以不用注解的方式,配置啟動類

//過濾器
  @Bean
  public FilterRegistrationBean filterRegistrationBean(){
    FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean();
    List<String> urlPatterns = new ArrayList<String>();
 
    TestFilter testFilter = new TestFilter();  //new過濾器
    urlPatterns.add("/Blogs");   //指定需要過濾的url
    filterRegistrationBean.setFilter(testFilter);    //set
    filterRegistrationBean.setUrlPatterns(urlPatterns);   //set
 
    return filterRegistrationBean;
  }

這也是可以的,本人其實還是比較推薦這種方式添加過濾器

Interceptor的簡單實現(xiàn)

攔截器的實現(xiàn)比過濾器稍微復(fù)雜一點

我們同樣可以新建一個interceptor包

在里面新建一個名為MyInterceptor的類

public class MyInterceptor implements HandlerInterceptor {}

這個類實現(xiàn)了HandleInterceptor接口

直接貼類代碼,我會在代碼中注釋功能

public class MyInterceptor implements HandlerInterceptor {
  //在請求處理之前進行調(diào)用(Controller方法調(diào)用之前
  @Override
  public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
    System.out.printf("preHandle被調(diào)用");
    return true;  //如果false,停止流程,api被攔截
  }
 
  //請求處理之后進行調(diào)用,但是在視圖被渲染之前(Controller方法調(diào)用之后)
  @Override
  public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
    System.out.println("postHandle被調(diào)用");
  }
 
  //在整個請求結(jié)束之后被調(diào)用,也就是在DispatcherServlet 渲染了對應(yīng)的視圖之后執(zhí)行(主要是用于進行資源清理工作)
  @Override
  public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
    System.out.println("afterCompletion被調(diào)用");
  }
}

它依次實現(xiàn)了三個方法

相比過濾器,攔截器還需要在springmvc中注入

所以我們打開啟動類,寫入以下代碼

public class WarApplication {
 
  public static void main(String[] args) {
    SpringApplication.run(WarApplication.class, args);
  }
 
  //mvc控制器
  //@Configuration
  static class WebMvcConfigurer extends WebMvcConfigurerAdapter{
    //增加攔截器
    public void addInterceptors(InterceptorRegistry registry){
      registry.addInterceptor(new MyInterceptor())  //指定攔截器類
          .addPathPatterns("/Handles");    //指定該類攔截的url
    }
  }
}

這里我在/Handles這個url中進行攔截

代碼寫完了,來看下結(jié)果

當(dāng)進入指定url時,我們執(zhí)行到了攔截器

接下來就可以根據(jù)需求去使用攔截器了

區(qū)別

過濾器和攔截器非常相似,但是它們有很大的區(qū)別

最簡單明了的區(qū)別就是過濾器可以修改request,而攔截器不能

過濾器需要在servlet容器中實現(xiàn),攔截器可以適用于javaEE,javaSE等各種環(huán)境

攔截器可以調(diào)用IOC容器中的各種依賴,而過濾器不能

過濾器只能在請求的前后使用,而攔截器可以詳細(xì)到每個方法

區(qū)別很多,大家可以去查下

總的來說

過濾器就是篩選出你要的東西,比如requeset中你要的那部分

攔截器在做安全方面用的比較多,比如終止一些流程

以上這篇詳談springboot過濾器和攔截器的實現(xiàn)及區(qū)別就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI