SpringBoot解決跨域問題小結(jié)
SpringBoot解決跨域問題
遇到前端跨域訪問問題,類似于這樣的:
在Springboot項目里加上這個配置文件CorsConfig.java
,重啟之后即可實現(xiàn)跨域訪問,前端無需再配置跨域。
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web.cors.CorsConfiguration; import org.springframework.web.cors.UrlBasedCorsConfigurationSource; import org.springframework.web.filter.CorsFilter; @Configuration public class CorsConfig { // 當(dāng)前跨域請求最大有效時長。這里默認1天 private static final long MAX_AGE = 24 * 60 * 60; @Bean public CorsFilter corsFilter() { UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); CorsConfiguration corsConfiguration = new CorsConfiguration(); corsConfiguration.addAllowedOrigin("*"); // 1 設(shè)置訪問源地址 corsConfiguration.addAllowedHeader("*"); // 2 設(shè)置訪問源請求頭 corsConfiguration.addAllowedMethod("*"); // 3 設(shè)置訪問源請求方法 corsConfiguration.setMaxAge(MAX_AGE); source.registerCorsConfiguration("/**", corsConfiguration); // 4 對接口配置跨域設(shè)置 return new CorsFilter(source); } }
注意,加完這個配置類后一定要 重啟后臺
?。?!
Spring Boot 中實現(xiàn)跨域的方式匯總
前言
在現(xiàn)代Web應(yīng)用中,由于安全性和隱私的考慮,瀏覽器限制了從一個域向另一個域發(fā)起的跨域HTTP請求。解決這個問題的一種常見方式是實現(xiàn)跨域資源共享(CORS)。Spring Boot提供了多種方式來處理跨域請求,本文將介紹其中的幾種方法。
1. 使用@CrossOrigin注解
Spring Boot提供了一個注解@CrossOrigin
,可以直接應(yīng)用于控制器類或方法上,以聲明允許跨域請求的配置。例如:
@RestController @CrossOrigin(origins = "http://localhost:3000") public class MyController { // Controller methods }
這種方法簡單明了,但可能不夠靈活,特別是當(dāng)需要配置更多的跨域選項時。
2. 使用WebMvcConfigurer配置
通過實現(xiàn)WebMvcConfigurer
接口,可以進行更細粒度的跨域配置。下面是一個例子:
@Configuration public class WebConfig implements WebMvcConfigurer { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/api/**") .allowedOrigins("http://localhost:3000") .allowedMethods("GET", "POST", "PUT", "DELETE") .allowCredentials(true); } }
這種方式允許更多的自定義配置,適用于復(fù)雜的跨域場景。
3. 使用Filter配置
通過自定義Filter
來處理跨域請求也是一種有效的方式。創(chuàng)建一個CorsFilter
類,實現(xiàn)Filter
接口:
@Component public class CorsFilter implements Filter { @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletResponse httpResponse = (HttpServletResponse) response; httpResponse.setHeader("Access-Control-Allow-Origin", "http://localhost:3000"); httpResponse.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE"); httpResponse.setHeader("Access-Control-Allow-Credentials", "true"); chain.doFilter(request, response); } }
然后,將該Filter注冊到Spring Boot應(yīng)用中。
4. 使用全局配置
在application.properties
或application.yml
中添加全局配置項:
spring.mvc.cors.allowed-origins=http://localhost:3000 spring.mvc.cors.allowed-methods=GET,POST,PUT,DELETE spring.mvc.cors.allow-credentials=true
這種方式不需要編寫額外的Java代碼,適用于全局的跨域配置。
結(jié)束語
Spring Boot提供了多種方式來實現(xiàn)跨域請求,開發(fā)者可以根據(jù)具體需求選擇適合的方法。在配置時,要確保不僅考慮安全性,還要兼顧應(yīng)用的靈活性和性能。希望本文對你理解Spring Boot中跨域配置提供了一些幫助。
到此這篇關(guān)于Spring Boot 中實現(xiàn)跨域的幾種方式的文章就介紹到這了,更多相關(guān)Spring Boot 跨域內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在idea中使用JaCoCo插件統(tǒng)計單元測試覆蓋率的實現(xiàn)
這篇文章主要介紹了在idea中使用JaCoCo插件統(tǒng)計單元測試覆蓋率的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01在SpringBoot 中從application.yml中獲取自定義常量方式
這篇文章主要介紹了在SpringBoot 中從application.yml中獲取自定義常量方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04java使用ZipInputStream實現(xiàn)讀取和寫入zip文件
zip文檔可以以壓縮格式存儲一個或多個文件,本文主要為大家詳細介紹了java如何使用ZipInputStream讀取Zip文檔與寫入,需要的小伙伴可以參考下2023-11-11java 中Executor, ExecutorService 和 Executors 間的不同
這篇文章主要介紹了java 中Executor, ExecutorService 和 Executors 間的不同的相關(guān)資料,需要的朋友可以參考下2017-06-06