Spring Boot配置過濾器的兩種方式
- 2019 年 10 月 3 日
- 筆記
過濾器(Filter)是Servlet中常用的技術,可以實現用戶在訪問某個目標資源之前,對訪問的請求和響應進行攔截,常用的場景有登錄校驗、權限控制、敏感詞過濾等,下面介紹下Spring Boot配置過濾器的兩種方式。
本文目錄
一、@WebFilter註解方式二、@Bean註解方式三、查看運行效果
一、@WebFilter註解方式
使用@WebFilter註解為聲明當前類為filter,第一個參數為該filter起一個名字,第二個參數為說明要攔截的請求地址,當前類需要實現Filter接口,裏面有三個方法,分別為過濾器初始化、過濾方法和過濾器銷毀。
@Slf4j
@WebFilter(filterName = "myFilter1", urlPatterns = "/*")
public class MyFilter1 implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
log.info(filterConfig.getFilterName() + " init");
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) {
log.info("myFilter1 begin");
try {
log.info("業務方法執行");
chain.doFilter(request, response);
} catch (Exception e) {
log.error("error!", e);
}
log.info("myFilter1 end");
}
@Override
public void destroy() {
}
}
啟動類添加@ServletComponentScan註解,@ServletComponentScan註解所掃描的包路徑必須包含該Filter,代碼如下:
@SpringBootApplication
@ServletComponentScan(basePackages = "com.example.demo.filter")
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
二、@Bean註解方式
新建MyFilter2.java類,不要加註解@WebFilter,代碼如下:
@Slf4j
public class MyFilter2 implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
log.info(filterConfig.getFilterName() + " init");
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) {
log.info("myFilter2 begin");
try {
log.info("業務方法執行");
chain.doFilter(request, response);
} catch (Exception e) {
log.error("error!", e);
}
log.info("myFilter2 end");
}
@Override
public void destroy() {
}
}
新建配置類WebConfig.java,配置bean,代碼如下:
@Configuration
public class WebConfig {
@Bean
public FilterRegistrationBean testFilterRegistration() {
FilterRegistrationBean registration = new FilterRegistrationBean(new MyFilter2());
registration.addUrlPatterns("/test"); //
registration.setName("myFilter2");
return registration;
}
}
三、查看運行效果
項目啟動後瀏覽器訪問http://localhost:8080/test,可以看到過濾器已生效,後台打印日誌如下:
[nio-8080-exec-1] com.example.demo.filter.MyFilter1 : myFilter1 begin
[nio-8080-exec-1] com.example.demo.filter.MyFilter1 : 業務方法執行
[nio-8080-exec-1] com.example.demo.filter.MyFilter1 : myFilter1 end
到此Spring Boot配置過濾器的兩種方式已經全部實現,有問題歡迎留言溝通哦!
完整源碼地址: https://github.com/suisui2019/springboot-study
推薦閱讀
1.Spring Boot統一異常處理實戰
2.從技術的角度分析下為什麼不要在網上發“原圖”
3.利用Spring Boot+zxing,生成二維碼還能這麼簡單
4.Spring Boot之Profile–快速搞定多環境使用與切換
5.利用Spring Boot+WxJava實現網站集成微信登錄功能
限時領取免費Java相關資料,涵蓋了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo/Kafka、Hadoop、Hbase、Flink等高並發分佈式、大數據、機器學習等技術。
關注下方公眾號即可免費領取:
Java碎碎念公眾號