解決SpringBoot自定義攔截器和跨域配置沖突的問題
SpringBoot自定義攔截器和跨域配置沖突
技術(shù)棧
vue-cli3,springboot 2.3.2.RELEASE
問題引出
在做畢業(yè)設(shè)計(jì)過程中用到了自定義攔截器驗(yàn)證登錄。同時(shí)在springboot配置類中設(shè)置了跨域問題,出現(xiàn)跨域失敗的情況。
原代碼
@Configuration public class WebConfig extends WebMvcConfigurationSupport { @Override protected void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") .allowedOrigins("*") .allowedMethods("GET", "HEAD", "POST","PUT", "DELETE", "OPTIONS") .allowedHeaders("*") .maxAge(3600); super.addCorsMappings(registry); } @Override protected void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new AuthInterceptor()) .addPathPatterns("/**") .excludePathPatterns("/login/*","/register/*"); } }
經(jīng)過了解和排查發(fā)現(xiàn),當(dāng)有請求發(fā)送到后臺時(shí),先被自定義攔截器攔截,如果攔截器驗(yàn)證沒有問題,才會開始執(zhí)行跨域配置。因此解決辦法是讓跨域配置在自定義攔截器之前執(zhí)行。而Filter的執(zhí)行順序大于自定義攔截器,因此可以在Filter中實(shí)現(xiàn)跨域的配置。
新代碼
@Configuration public class WebConfig extends WebMvcConfigurationSupport { @Override protected void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new AuthInterceptor()) .addPathPatterns("/**") .excludePathPatterns("/login/*","/register/*"); } }
添加Filter
@Configuration public class MyCorsFilter{ private CorsConfiguration corsConfig(){ CorsConfiguration corsConfiguration = new CorsConfiguration(); corsConfiguration.addAllowedHeader("*"); corsConfiguration.addAllowedMethod("*"); corsConfiguration.addAllowedOrigin("*"); corsConfiguration.setMaxAge(3600L); corsConfiguration.setAllowCredentials(true); return corsConfiguration; } @Bean public CorsFilter corsFilter(){ UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); source.registerCorsConfiguration("/**",corsConfig()); return new CorsFilter(source); } }
SpringBoot 攔截器和addCorsMappings沖突
項(xiàng)目中最開始跨域問題是通過自定義過濾器CorsFilter對request處理的,可以很好的解決問題?! ?/p>
最近,新項(xiàng)目中準(zhǔn)備通過如下代碼解決跨域問題,結(jié)果發(fā)現(xiàn)登錄超時(shí)的錯(cuò)誤會出現(xiàn)跨域問題,其他問題都不會。
@Configuration public class WebConfig extends WebMvcConfigurerAdapter { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**"); } }
因?yàn)榈卿洺瑫r(shí)的檢查是在攔截器中,所以推測是可能是攔截器的執(zhí)行在addCorsMappings生效之前。將CorsFilter代碼拿到項(xiàng)目中后,果然沒有這個(gè)問題了。所以這個(gè)bu基本上可以認(rèn)定是是攔截器和addCorsMappings生效順序的問題。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
阿里巴巴 Sentinel + InfluxDB + Chronograf 實(shí)現(xiàn)監(jiān)控大屏
這篇文章主要介紹了阿里巴巴 Sentinel + InfluxDB + Chronograf 實(shí)現(xiàn)監(jiān)控大屏,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09Java中List集合去除重復(fù)數(shù)據(jù)的方法匯總
這篇文章主要給大家介紹了關(guān)于Java中List集合去除重復(fù)數(shù)據(jù)的方法,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02Java微服務(wù)Nacos Config配置中心超詳細(xì)講解
配置文件相對分散。在一個(gè)微服務(wù)架構(gòu)下,配置文件會隨著微服務(wù)的增多變的越來越多,而且分散 在各個(gè)微服務(wù)中,不好統(tǒng)一配置和管理。每一個(gè)環(huán)境所使用的配置理論上都是不同的,一旦需要修改,就需要我們?nèi)ジ鱾€(gè)微服務(wù)下手動維護(hù)2023-02-02