vue 解決axios請求出現前端跨域問題


vue 解決axios請求出現前端跨域問題

在這里插入圖片描述

最近在寫純前端的vue項目的時候,碰到了axios請求本機的資源的時候,出現了訪問報404的問題。這就讓我很難受。查詢了資料原來是跨域的問題。

在正常開發中跨域問題有很多的解決方案。最常見的就是后端修改響應頭。但是前端也可以解決,通過反向代理。為了防止下一次這樣的錯誤出現,記錄一下,總結一下。

所以現在我們來復盤一下,然后解決掉。

一、為什么會出現跨域的問題?

跨域:瀏覽器從一個域名的網頁去請求另一個域名的資源時,域名、端口、協議任一不同,都是跨域。

在前后端分離的模式下,前后端的域名是不一致的,此時就會發生跨域訪問問題。跨域問題來源於JavaScript的同源策略,即只有 協議+主機名+端口號(如存在)相同,則允許相互訪問。也就是說JavaScript只能訪問和操作自己域下的資源,不能訪問和操作其他域下的資源。跨域問題是針對JS和ajax的。而axios是通過Promise實現對ajax技術的一種封裝,也同樣存在跨域問題。

二、解決方案

這里我就使用本機的開啟兩個不同的端口來測試。

未處理跨域前的報錯

在這里插入圖片描述
沒有做跨域處理請求是這樣的

 axios.get('http://localhost:8080/getData')
 .then(res => {
   console.log(res)
 })
 .catch(err => {
   console.error(err); 
 })

跨域資源共享(CORS)

前端進行反向代理來解決跨域問題。原理圖如下:

  1. vue項目的端口是8081

在這里插入圖片描述

  1. 自己電腦開啟了一個8080的端口,請求/getData就會放回json數據。

  2. 配置代理

1.在vue2.0中

修改config文件夾下的index.js文件,在proxyTable中加上如下代碼:

   proxyTable: {
      '/apis': {
        target: 'http://localhost:8080/',  //要解決跨域的接口的域名
        secure:false,           //如果是https接口,需要配置這個參數
        changeOrigin: true,  // 如果接口跨域,需要進行這個參數配置
        pathRewrite: {
          '^/apis': ''  // 路徑重寫
        }
      },
    },

然后在請求中axios中這樣寫

 axios.get('apis/getData')
 .then(res => {
   console.log(res)
 })
 .catch(err => {
   console.error(err); 
 })

分析:
target后面的就是需要請求的網址的公共部分,然后用/apis來代理這個,最后重寫一些路徑,請求的時候使用的我們的代理的apis來作為前綴。
這個前綴我們可以自定義,proxyTable是對象,所以我們可以配多個代理。

跨域解決

在這里插入圖片描述

2.在vue3.0中

vue-cli3 腳手架搭建完成后,項目目錄中沒有 vue.config.js 文件,需要手動創建

新建一個vue.config.js,配置以下信息,同樣可以解決。

module.exports = {   
    devServer: {
        proxy: {
            '^/api': {
                target: 'http://localhost:8080/',//接口的前綴
                ws:true,//代理websocked
                changeOrigin:true,//虛擬的站點需要更管origin
                pathRewrite:{
                    '^/api':''//重寫路徑
                }
            }
        }
    }
}

小結:

changeOrigin: true :開啟代理:在本地會創建一個虛假服務器,然后發送請求的數據,並同時接收請求的數據,這樣服務端和服務端就可以進行數據的交互。

apis就是接口實際請求的前綴,去代理了我們的實際的接口前綴的公共部分,也就是協議+主機名+端口號

比如 請求接口為localhost:8080/getData 我們只需要傳入:getData
那么公共的域名就是 localhost:8080/,我們就是在請求接口的公共域名localhost:8080/改為api/即可!

把項目運行起來可以看到接口請求的路徑為 :localhost:8081/apis/getData
而進過代理后,實際的請求路徑是 : localhost:8080/getData

寫在最后

在學習中還是要多看官方文檔,在跨域等配置問題上,官方文檔也給出了很多的配置信息,vue cli配置

總結一下最近的現象:只要累不死,就往死里卷。加油各位。

歡迎大佬來點評文章,技術交流。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM