欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Boot前后端分離開(kāi)發(fā)模式中的跨域問(wèn)題及解決方法

 更新時(shí)間:2023年09月01日 15:24:44   作者:java李楊勇  
本文介紹了解決Spring Boot前端Vue跨域問(wèn)題的實(shí)戰(zhàn)經(jīng)驗(yàn),并提供了后端和前端的配置示例,通過(guò)配置后端和前端,我們可以輕松解決跨域問(wèn)題,實(shí)現(xiàn)正常的前后端交互,需要的朋友可以參考下

在實(shí)際開(kāi)發(fā)中,經(jīng)常會(huì)遇到前端Vue應(yīng)用與后端Spring Boot API接口存在跨域訪問(wèn)的問(wèn)題。本篇博客將分享解決Spring Boot前端Vue跨域問(wèn)題的實(shí)戰(zhàn)經(jīng)驗(yàn),幫助開(kāi)發(fā)者快速解決該問(wèn)題。

一、跨域問(wèn)題的原因

跨域問(wèn)題是由于瀏覽器的同源策略引起的。同源策略限制了從一個(gè)源加載的文檔或腳本如何與來(lái)自另一個(gè)源的資源進(jìn)行交互。當(dāng)協(xié)議、主機(jī)名或端口號(hào)不同時(shí),瀏覽器就會(huì)認(rèn)為這是跨域訪問(wèn),從而拒絕請(qǐng)求。

二、解決方案

1. 后端配置

在Spring Boot后端項(xiàng)目中,我們可以通過(guò)添加跨域配置允許前端Vue應(yīng)用的跨域請(qǐng)求。

@Configuration
public class CorsConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedOrigins("*")
                .allowedMethods("*")
                .allowedHeaders("*")
                .allowCredentials(true)
                .maxAge(3600);
    }
}

以上代碼中使用 @Configuration 注解標(biāo)注一個(gè)配置類(lèi),并實(shí)現(xiàn) WebMvcConfigurer 接口。在 addCorsMappings 方法中,配置了允許所有來(lái)源( allowedOrigins("*") )、所有HTTP方法( allowedMethods("*") )、所有請(qǐng)求頭( allowedHeaders("*") )、支持跨域攜帶Cookie( allowCredentials(true) )以及緩存時(shí)間( maxAge(3600) )。

2. 前端配置

在Vue前端項(xiàng)目中,我們可以通過(guò)配置 vue.config.js 文件來(lái)解決跨域問(wèn)題。

module.exports = {
    devServer: {
        proxy: {
            '/api': {
                target 'http://localhost:8080',  // 后端API接口地址
                changeOrigin: true,
                pathRewrite: {
                    '^/api': ''
                }
            }
        }
    }
}

以上代碼中,我們通過(guò) devServer 配置項(xiàng)的 proxy 屬性來(lái)配置代理。將請(qǐng)求路徑中以 api 開(kāi)頭的請(qǐng)求代理到指定的后端API接口地址(這里是 http://localhost:8080 )。 changeOrigin 設(shè)置為 true 表示開(kāi)啟跨域。

三、實(shí)戰(zhàn)示例

在實(shí)際開(kāi)發(fā)中,我們可以通過(guò)以下示例來(lái)演示解決Spring Boot端Vue跨域問(wèn)題的實(shí)戰(zhàn)經(jīng)驗(yàn)。

后端代碼示例:

@RestController
@RequestMapping("/api")
public class HelloController {
    @GetMapping("/hello")
    public String hello() {
        return "Hello, World!";
    }
}
```javascript
axios.get('/api/hello')
    .then(response => {
        console.log(response.data);
    })
    .catch(error => {
        console.error(error);
    });

以上示例中,后端提供了一個(gè)簡(jiǎn)單的接口 /api/hello ,前端通過(guò) axios 發(fā)送GET請(qǐng)求來(lái)獲取數(shù)據(jù)。

四、總結(jié)

本篇博客介紹了解決Spring Boot前端Vue跨域問(wèn)題的實(shí)戰(zhàn)經(jīng)驗(yàn),并提供了后端和前端的配置示例。通過(guò)配置后端和前端,我們可以輕松解決跨域問(wèn)題,實(shí)現(xiàn)正常的前后端交互。

以上內(nèi)容僅供參考,具體情況還需根實(shí)際項(xiàng)目進(jìn)行調(diào)整。如有更好的解決方案,歡迎留言討論。

到此這篇關(guān)于Spring Boot前后端分離開(kāi)發(fā)模式中的跨域問(wèn)題的文章就介紹到這了,更多相關(guān)Spring Boot前后端分離跨域內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java 集合并發(fā)操作出現(xiàn)的異常ConcurrentModificationException

    java 集合并發(fā)操作出現(xiàn)的異常ConcurrentModificationException

    Map在遍歷時(shí)候通常 現(xiàn)獲得其鍵值的集合Set,然后用迭代器Iterator來(lái)對(duì)Map進(jìn)行遍歷。
    2009-06-06
  • IntelliJ?IDEA教程之clean或者install?Maven項(xiàng)目的操作方法

    IntelliJ?IDEA教程之clean或者install?Maven項(xiàng)目的操作方法

    這篇文章主要介紹了IntelliJ?IDEA教程之clean或者install?Maven項(xiàng)目的操作方法,本文分步驟給大家介紹兩種方式講解如何調(diào)試出窗口,需要的朋友可以參考下
    2023-04-04
  • Spring自動(dòng)裝配之方法、構(gòu)造器位置的自動(dòng)注入操作

    Spring自動(dòng)裝配之方法、構(gòu)造器位置的自動(dòng)注入操作

    這篇文章主要介紹了Spring自動(dòng)裝配之方法、構(gòu)造器位置的自動(dòng)注入操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • java 單元測(cè)試 對(duì)h2數(shù)據(jù)庫(kù)數(shù)據(jù)清理方式

    java 單元測(cè)試 對(duì)h2數(shù)據(jù)庫(kù)數(shù)據(jù)清理方式

    這篇文章主要介紹了java 單元測(cè)試 對(duì)h2數(shù)據(jù)庫(kù)數(shù)據(jù)清理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Spring boot項(xiàng)目打包成jar運(yùn)行的二種方法

    Spring boot項(xiàng)目打包成jar運(yùn)行的二種方法

    這篇文章主要給大家介紹了關(guān)于Spring boot項(xiàng)目打包成jar運(yùn)行的二種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用spring boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • Springboot2.x 使用 Log4j2 異步打印日志的實(shí)現(xiàn)

    Springboot2.x 使用 Log4j2 異步打印日志的實(shí)現(xiàn)

    這篇文章主要介紹了Springboot2.x 使用 Log4j2 異步打印日志的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 使用Guava?Cache原理及最佳實(shí)踐

    使用Guava?Cache原理及最佳實(shí)踐

    文章介紹了GuavaCache,這是一種支持高并發(fā)的本地緩存,它支持多種回收策略,如基于容量、時(shí)間和引用的回收,并提供了自動(dòng)加載、定時(shí)刷新和顯式清除緩存的功能,文章還討論了GuavaCache的適用場(chǎng)景和使用方法,并通過(guò)代碼示例和源碼分析,幫助讀者更好地理解和使用GuavaCache
    2025-02-02
  • SpringMvc后臺(tái)接收json數(shù)據(jù)中文亂碼問(wèn)題詳解

    SpringMvc后臺(tái)接收json數(shù)據(jù)中文亂碼問(wèn)題詳解

    這篇文章主要介紹了SpringMvc后臺(tái)接收json數(shù)據(jù)中文亂碼問(wèn)題詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • Java 基礎(chǔ)語(yǔ)法之解析 Java 的包和繼承

    Java 基礎(chǔ)語(yǔ)法之解析 Java 的包和繼承

    包是組織類(lèi)的一種方式,繼承顧名思義,比如誰(shuí)繼承了長(zhǎng)輩的產(chǎn)業(yè),其實(shí)這里的繼承和我們生活中的繼承很類(lèi)似,下面文字將為大家詳細(xì)介紹Java的包和繼承
    2021-09-09
  • java:程序包org.apache.ibatis.annotations不存在報(bào)錯(cuò)解決

    java:程序包org.apache.ibatis.annotations不存在報(bào)錯(cuò)解決

    這篇文章主要給大家介紹了關(guān)于java:程序包org.apache.ibatis.annotations不存在報(bào)錯(cuò)的解決方法,這個(gè)錯(cuò)誤是我在直接導(dǎo)入springboot項(xiàng)目的時(shí)候報(bào)錯(cuò)的,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04

最新評(píng)論