Spring Boot 編寫自己的"過濾器" 又好久沒有寫博客進行總結了,說實話,就是 "懶",懶得總結,懶得動.之所以寫這篇博客,是因為最近對接公司SSO服務的時候,需要自定義攔截器,spring mvc 中xml的配置文章可以在網上找到很多,但是由於我用的是 Spring boot ,你也知道, ...
Spring Boot 編寫自己的"過濾器"
又好久沒有寫博客進行總結了,說實話,就是 "懶",懶得總結,懶得動.之所以寫這篇博客,是因為最近對接公司SSO服務的時候,需要自定義攔截器,spring mvc 中xml的配置文章可以在網上找到很多,但是由於我用的是 Spring boot ,你也知道, Spring Boot 簡化了很多配置文件,同時也整合了很多註解.面對新的需求,我匆忙間急得各種查找 Spring Boot 下 Web.xml 的配置文件如何載入.缺乏理性思考的後果就是走入了誤區.浪費了些時間.
其實Spring Boot 對於 web.xml類的配置文件都實現了通過編碼來代替,比如通過 @Configuration 我們可以進行自定義的配置 等等.但是面對公司業務文檔中提到的解決方案是通過web.xml來配置攔截器來解決的,所以一直用著Spring boot的同時,還非要嫁接web.xml.整個問題的解決思路不清晰.所以再次告誡自己,遇事還是要冷靜,急於達到結果的後果往往是浪費了時間和精力,問題卻沒有解決,如果您現在在看這篇博問,我想您一定是遇到了同類問題,別急,先休息休息,冷靜一下,保持inner peace.
開始說到 Spring Boot 自定義過濾器前,我們不得不說一下 Servlet,關於Servlet 的解釋,我覺得百科上的解釋比較準確些:
Servlet(Server Applet)是Java Servlet的簡稱,稱為小服務程式或服務連接器,用Java編寫的伺服器端程式,具有獨立於平臺和協議的特性,主要功能在於互動式地瀏覽和生成數據,生成動態Web內容。
狹義的Servlet是指Java語言實現的一個介面,廣義的Servlet是指任何實現了這個Servlet介面的類,一般情況下,人們將Servlet理解為後者。Servlet運行於支持Java的應用伺服器中。從原理上講,Servlet可以響應任何類型的請求,但絕大多數情況下Servlet只用來擴展基於HTTP協議的Web伺服器。
最早支持Servlet標準的是JavaSoft的Java Web Server,此後,一些其它的基於Java的Web伺服器開始支持標準的Servlet。
Servlet就像是一個容器,裡面有各種組件,採用"請求-響應"的模式來提供web服務,既然是容器,就意味這我們可以放置一些自定義的組件和服務
這裡有幾個概念,我記錄下,大家可以順著記憶回憶回憶,面試也會經常問到的關鍵詞,"Web伺服器","Servlet","Tomcat" ,其實最會被問到的應該是"Servlet"和"Tomcat"的關係.
上代碼:
1.記得創建類文件 SsoFilterManager ,通過 @Service 標註為服務,代碼我們自定義了自己的過濾器 "SSOWebRequiredFilterV2Register",SSOWebRequiredFilterV2的類其實是我對接服務方提供的一個類,這個類實現了Filter,並重寫了doFilter 的方法,同時我們也配置了攔截地址:"/sso/account/safe/*",那麼通過這個地址來的請求的請求都會交由SSOWebRequiredFilterV2的類來處理
@Service public class SsoFilterManager { @Bean(name = "SSOWebRequiredFilterV2Register") FilterRegistrationBean SSOWebRequiredFilterV2Register() { FilterRegistrationBean registrationBean = new FilterRegistrationBean(); SSOWebRequiredFilterV2 ssoWebRequiredFilterV2 = new SSOWebRequiredFilterV2(); registrationBean.setFilter(ssoWebRequiredFilterV2); registrationBean.addUrlPatterns("/sso/account/safe/*"); return registrationBean; } }
2.SSoServletManager 也要單起一個類文件,通過ServletRegistrationBean 來註冊一個servlet,STSServlet 也是我對接服務方提供的Servlet服務,他繼承了HttpServlet,並且擴展了doGet的方法,"/sso/account/sts" 地址請求將交由STSServlet來處理.
@Service public class SSoServletManager { @Bean public ServletRegistrationBean STSServerletRegister(){ STSServlet stsServlet = new STSServlet(); ServletRegistrationBean registration = new ServletRegistrationBean(stsServlet); registration.setEnabled(true); registration.addUrlMappings("/sso/account/sts"); return registration; } }
SSO類的業務對接,主要是引入SSO服務方的相關包,然後配置攔截器,相應的按照服務提供方的要求配置一下回調地址,即可完成,Spring Boot 的對接無非是將以往Web.xml的配置形式轉換成了額代碼的方式來實現,但是思路活整體流程是一致的.
對不起,我又當了回資料的搬運工,但是很有收穫,每次寫博客的過程就是一個溫故而知新的過程,也有利於一些知識的鞏固.還是那句話,不忘初心,好了,就寫到這裡,我是百靈