SpringBoot中解決跨域的多種實現(xiàn)方式
在開發(fā)Web應(yīng)用時,經(jīng)常會遇到跨域問題,這給開發(fā)者帶來了不少困擾。
在本文中,我將探討Spring Boot中解決跨域問題的幾種常見方式,包括使用@CrossOrigin注解、自定義WebMvcConfigurer以及使用Filter進行跨域配置。
通過深入了解這些方法,我們能夠更好地解決跨域問題,保證應(yīng)用的穩(wěn)定性和安全性。
引言
跨域問題是指在Web開發(fā)中,當(dāng)一個域(domain)的JavaScript代碼去請求另一個域的資源時,瀏覽器會出于安全考慮阻止這種跨域的行為。
在開發(fā)過程中,經(jīng)常會遇到前端與后端不在同一個域的情況,因此跨域問題就顯得尤為重要。
何為跨域
跨域是指在瀏覽器中,一個域下的JavaScript代碼試圖訪問另一個域下的資源時所遇到的限制。
這種限制是由同源策略(Same-Origin Policy)所引起的。
同源策略要求瀏覽器只能在同一個域中加載頁面和執(zhí)行腳本,而不能跨域進行操作。
跨域問題出現(xiàn)特征
跨域問題通常表現(xiàn)為瀏覽器的跨域安全限制,導(dǎo)致前端頁面無法獲取或操作來自其他域的資源。
這可能導(dǎo)致頁面功能無法正常工作,或者出現(xiàn)安全漏洞。

方式一:使用 @CrossOrigin 注解
在Spring Boot中,可以通過在Controller類或方法上添加@CrossOrigin注解來解決跨域問題。
這個注解可以指定允許跨域訪問的域名、方法、頭部信息等。
@CrossOrigin(origins = "*")//允許所有來源的請求跨域
@RestController
public class MyController {
@GetMapping("/hello")
public String hello() {
return "Hello, World!";
}
}這種方式解決跨域需要在每個控制器上加注解,屬于重復(fù)勞動對于不需要精確控制的場景屬于重復(fù)勞動。
可以看下下面方式:
方式二:自定義 WebMvcConfigurer
另一種解決跨域問題的方式是通過自定義WebMvcConfigurer來配置跨域策略。
這種方式更加靈活,可以針對不同的路徑進行不同的跨域配置。
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
/**
* 跨域配置類。
* 允許所有路徑的跨域請求。
* 配置允許的源地址、請求方法和請求頭。
*
* @author mijiupro
*/
@Configuration
public class WebConfig implements WebMvcConfigurer {
/**
* 配置跨域映射。
*
* @param registry 跨域注冊表
*/
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**") // 對所有路徑生效
.allowedOrigins("*") // 允許所有源地址
// .allowedOrigins("https://mijiupro.com","https://mijiu.com ") // 允許的源地址(數(shù)組)
.allowedMethods("GET", "POST", "PUT", "DELETE") // 允許的請求方法
.allowedHeaders("*"); // 允許的請求頭
}
}這種方式實現(xiàn)了全局的配置,但是無法細(xì)膩到控制某個方法
方式三:使用 Filter 進行跨域配置
除了以上兩種方式外,還可以通過自定義Filter來處理跨域請求。
這種方式可以更加靈活地控制跨域策略,適用于更復(fù)雜的跨域場景。
import jakarta.servlet.*;
import jakarta.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Component;
import java.io.IOException;
/**
* 跨域過濾器。
* 用于處理跨域請求。
*
* @author mijiupro
*/
@Component
public class CorsFilter implements Filter {
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
// 將 ServletResponse 轉(zhuǎn)換為 HttpServletResponse
HttpServletResponse httpResponse = (HttpServletResponse) response;
// 設(shè)置允許跨域請求的源地址
httpResponse.setHeader("Access-Control-Allow-Origin", "https://mijiupro.com");
// 設(shè)置允許的請求方法
httpResponse.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");
// 設(shè)置允許的請求頭
httpResponse.setHeader("Access-Control-Allow-Headers", "*");
// 繼續(xù)執(zhí)行 Filter 鏈
chain.doFilter(request, response);
}
}結(jié)論
通過本文的介紹,我們了解了在Spring Boot中解決跨域問題的幾種常見方式,包括使用@CrossOrigin注解、自定義WebMvcConfigurer以及使用Filter進行跨域配置。
針對不同的場景和需求,我們可以選擇合適的方式來解決跨域問題,保證應(yīng)用的穩(wěn)定性和安全性。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
參考資料:
相關(guān)文章
SpringBoot項目中Maven剔除無用Jar引用的最佳實踐
在?Spring?Boot?項目開發(fā)中,Maven?是最常用的構(gòu)建工具之一,通過?Maven,我們可以輕松地管理項目所需的依賴,而,隨著項目的復(fù)雜化,無用的?Jar?包引用可能會逐漸增多,本文旨在詳細(xì)解析如何在?Spring?Boot?項目中剔除無用的?Jar?引用,需要的朋友可以參考下2025-01-01
SSH框架網(wǎng)上商城項目第9戰(zhàn)之添加和更新商品類別功能實現(xiàn)
這篇文章主要為大家詳細(xì)介紹了SSH框架網(wǎng)上商城項目第9戰(zhàn)之添加和更新商品類別功能實現(xiàn),感興趣的小伙伴們可以參考一下2016-06-06
Java函數(shù)式編程(一):你好,Lambda表達式
這篇文章主要介紹了Java函數(shù)式編程(一):你好,Lambda表達式,本文講解了新老函數(shù)式編程的一些變化,需要的朋友可以參考下2014-09-09
Java基礎(chǔ)教程之基本類型數(shù)據(jù)類型、包裝類及自動拆裝箱
這篇文章主要給大家介紹了關(guān)于Java基礎(chǔ)教程之基本類型數(shù)據(jù)類型、包裝類及自動拆裝箱的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06

