SpringBoot解決跨域問題小結
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 {
// 當前跨域請求最大有效時長。這里默認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 設置訪問源地址
corsConfiguration.addAllowedHeader("*"); // 2 設置訪問源請求頭
corsConfiguration.addAllowedMethod("*"); // 3 設置訪問源請求方法
corsConfiguration.setMaxAge(MAX_AGE);
source.registerCorsConfiguration("/**", corsConfiguration); // 4 對接口配置跨域設置
return new CorsFilter(source);
}
}注意,加完這個配置類后一定要 重啟后臺 !??!
Spring Boot 中實現(xiàn)跨域的方式匯總

前言
在現(xiàn)代Web應用中,由于安全性和隱私的考慮,瀏覽器限制了從一個域向另一個域發(fā)起的跨域HTTP請求。解決這個問題的一種常見方式是實現(xiàn)跨域資源共享(CORS)。Spring Boot提供了多種方式來處理跨域請求,本文將介紹其中的幾種方法。
1. 使用@CrossOrigin注解
Spring Boot提供了一個注解@CrossOrigin,可以直接應用于控制器類或方法上,以聲明允許跨域請求的配置。例如:
@RestController
@CrossOrigin(origins = "http://localhost:3000")
public class MyController {
// Controller methods
}這種方法簡單明了,但可能不夠靈活,特別是當需要配置更多的跨域選項時。
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);
}
}這種方式允許更多的自定義配置,適用于復雜的跨域場景。
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應用中。
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代碼,適用于全局的跨域配置。
結束語
Spring Boot提供了多種方式來實現(xiàn)跨域請求,開發(fā)者可以根據(jù)具體需求選擇適合的方法。在配置時,要確保不僅考慮安全性,還要兼顧應用的靈活性和性能。希望本文對你理解Spring Boot中跨域配置提供了一些幫助。
到此這篇關于Spring Boot 中實現(xiàn)跨域的幾種方式的文章就介紹到這了,更多相關Spring Boot 跨域內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
在idea中使用JaCoCo插件統(tǒng)計單元測試覆蓋率的實現(xiàn)
這篇文章主要介紹了在idea中使用JaCoCo插件統(tǒng)計單元測試覆蓋率的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
在SpringBoot 中從application.yml中獲取自定義常量方式
這篇文章主要介紹了在SpringBoot 中從application.yml中獲取自定義常量方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04
java使用ZipInputStream實現(xiàn)讀取和寫入zip文件
zip文檔可以以壓縮格式存儲一個或多個文件,本文主要為大家詳細介紹了java如何使用ZipInputStream讀取Zip文檔與寫入,需要的小伙伴可以參考下2023-11-11
java 中Executor, ExecutorService 和 Executors 間的不同
這篇文章主要介紹了java 中Executor, ExecutorService 和 Executors 間的不同的相關資料,需要的朋友可以參考下2017-06-06

