亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue-cli3.x + axios 跨域方案踩坑指北

 更新時間:2019年07月04日 14:28:13   作者:熊飼  
這篇文章主要介紹了Vue-cli3.x + axios 跨域方案踩坑指北,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

緣起

最近實驗課上需要重構(gòu)以前寫過的一個項目(垃圾堆),需要添加發(fā)生郵件提醒的功能,記得以前寫過一個PHP版的實現(xiàn),所以想把PHP寫的功能整理成一個服務,然后在前端調(diào)用。但是這個項目是JavaWeb,也就是說我需要面對跨域的問題。不過本篇文章,講的并不是如何解決這樣的跨域問題,而是我在找如何解決這個問題的路上遇到的坑。

其實,在前端工程化大行其道的現(xiàn)在,前后端已經(jīng)分離開來,前端為了提高工作流效率往往自己開一個小型的服務器,就比如webpack.devServer。這樣在前端調(diào)用后端接口的時候必然會面臨跨域的問題,如題,Vue-cli 3.x + axios 跨域方案 就是解決這里的跨域問題。這里的跨域是基于webpack的devServer的代理功能(proxy)來實現(xiàn)開發(fā)環(huán)境中的跨域,也就是說本篇所討論的并不能解決生產(chǎn)環(huán)境下的跨域問題,因為webpack.devServer是DevDependencies,一旦打包上線,這個proxy代理就會失效。但是這并不妨礙我們開發(fā)中使用跨域來提高開發(fā)效率和體驗。

開始填坑

其實這個問題解決起來很簡單,網(wǎng)上也是很多教程,為了文章完整性,我這里也做一個盡量完備的展示,介紹如何配置Vue-cli 3.x來實現(xiàn)跨域 。

vue.config.js中devServer.proxy的配置解析

Vue-cli3.x比Vue-cli2.x構(gòu)建的項目要簡化很多,根目錄下只有./src和./public文件夾,所以網(wǎng)上很多教程說config目錄下的vue.config.js是說的vue-cli 2.x版本。那么對于Vue-cli 3.x版本,構(gòu)建也很簡單,直接在根目錄里建一個vue.config.js配置文件就可以了,我們直接看devServer.proxy里的代碼:

我這里devServer的地址是:localhost:8080/,需要代理的地址是:localhost/index/phpinfo.php (我自己寫的一個測試跨域用的php,返回一個‘ok')

下面是根據(jù)上面的地址需要配置的proxy對象

devServer : {
    proxy : {
      '/index' : {
        target : 'http://localhost/index',
        // ws : true,
        changeOrigin : true,
        pathRewrite : {
          '^/index' : ''
        }
      }
    }
  }

大部分教程到這里就停止了,但是我在這里做一個擴展,為了讓讀者理解這里的配置是如何起作用的(以下內(nèi)容整理自http-proxy-middleware的npm描述里,http-proxy-middleware是一個npm模塊,是proxy的底層原理實現(xiàn))。

     foo://example.com:8042/over/there?name=ferret#nose
     \_/  \______________/\_________/ \_________/ \__/
     |      |      |      |    |
    scheme   authority    path    query  fragment

以我上面的配置為例,'/index'這個key在http-proxy-middleware中被稱為context——用來決定哪些請求需要被target對應的主機地址(這里是http://localhost/index)代理,它可以是 字符串,含有通配符的字符串,或是一個數(shù)組,分別對應于path matching(路徑匹配)wildcard path matching(通配符路徑匹配)multiple path matching(多路徑匹配),而這里的path指的就是上圖所標識的path段。

簡言之,這個key就是匹配path的,一旦匹配到符合的path,就會把請求轉(zhuǎn)發(fā)的代理主機去,而代理主機的地址就是target字段對應的內(nèi)容。

那pathRewrit是什么意思呢?意如其名,路徑重寫。就是把模式(這里是^/index)匹配到的path重寫為對應的路徑(這里是'',相當于刪除了這個匹配到的路徑)。除了刪除,還有在原有路徑上添加一個基礎路徑,或是改寫一個路徑的方式,這可以參考http-proxy-middleware的npm描述的option.pathRewrite章節(jié) 。

在Vue中使用axios

這個使用任意一個ajax封裝的庫都是可行的,axios,jquery.ajax或者是vue-resource都是可以的。

在Vue中使用axios,網(wǎng)上有兩種方法,一種是將axios加入Vue的原型里,我更推薦第二種方法:

npm install axios vue-axios
import axios from 'axios';
import VueAxios from 'vue-axios';
Vue.use(VueAxios,axios);

以我上面的proxy配置為基礎,想要讓代理成功轉(zhuǎn)發(fā)到localhost/index/phpinfo.php,在Vue實例中axios需要這樣寫訪問地址:

this.axios.get('/index/phpinfo.php').then((res)=>{
    console.log(res);
   })

我們來分析這些代碼整個發(fā)揮作用的原理是什么?首先,axios去訪問/index/phpinfo.php,這是個相對地址,所以真實訪問地址其實是localhost:8080/index/phpinfo.php,然而/index/phpinfo.php被我們配置的/index匹配到了 ,所以訪問被proxy代理,那轉(zhuǎn)發(fā)到哪個路徑呢?在pathRewrite中,我們將模式^/index的路徑清除了,所以最終的訪問路徑是 target+pathRewrite+ 剩余的部分 , 這樣也就是 http://localhost/index++/phpinfo.php

坑點

可能出現(xiàn)即使配置了proxy,但是依然沒有任何卵用。

  • 大部分情況是因為你的proxy配置和你的訪問路徑不匹配,或者即使匹配到了,但是轉(zhuǎn)發(fā)出去的地址不對,沒有命中后端給的API
  • 或者看看axios,有沒有使用正確姿勢?
  • 還有一點,或許你看到返回的response里的url依然顯示的是本地主機,但是數(shù)據(jù)已經(jīng)正常返回,這是正常的,因為我們訪問的本來就是本地主機,只不過proxy轉(zhuǎn)發(fā)了這個請求到一個新的地址。

后續(xù)

本篇只解決了開發(fā)環(huán)境下的跨域問題,實際線上還不能跨域,目前這里有一些方案:

  1. Nginx反向代理跨域
  2. JSONP
  3. CORS

下一次討論這個跨域問題,嘗試解決。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Vue如何使用ElementUI對表單元素進行自定義校驗及踩坑

    Vue如何使用ElementUI對表單元素進行自定義校驗及踩坑

    有一些驗證不是通過input select這樣的受控組件來觸發(fā)驗證條件的 ,可以通過自定義驗證的方法來觸發(fā),下面這篇文章主要給大家介紹了關于Vue如何使用ElementUI對表單元素進行自定義校驗及踩坑的相關資料,需要的朋友可以參考下
    2023-02-02
  • vue.js引入外部CSS樣式和外部JS文件的方法

    vue.js引入外部CSS樣式和外部JS文件的方法

    這篇文章主要介紹了vue.js引入外部CSS樣式和外部JS文件的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • vue實現(xiàn)虛擬列表功能的代碼

    vue實現(xiàn)虛擬列表功能的代碼

    這篇文章主要介紹了vue實現(xiàn)虛擬列表,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • vue前端優(yōu)雅展示后端十萬條數(shù)據(jù)面試點剖析

    vue前端優(yōu)雅展示后端十萬條數(shù)據(jù)面試點剖析

    這篇文章主要為大家介紹了vue前端優(yōu)雅展示后端十萬條數(shù)據(jù)的考點剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • element?table?表格控件實現(xiàn)單選功能

    element?table?表格控件實現(xiàn)單選功能

    本文主要介紹了element?table?表格控件實現(xiàn)單選功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • vue如何通過點擊事件彈出彈窗頁面詳解

    vue如何通過點擊事件彈出彈窗頁面詳解

    彈窗是我們開發(fā)中經(jīng)常遇到的一個功能,下面這篇文章主要給大家介紹了關于vue如何通過點擊事件彈出彈窗頁面的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • vue打包chunk-vendors.js文件過大導致頁面加載緩慢的解決

    vue打包chunk-vendors.js文件過大導致頁面加載緩慢的解決

    這篇文章主要介紹了vue打包chunk-vendors.js文件過大導致頁面加載緩慢的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue項目中路徑使用@和~的區(qū)別及說明

    vue項目中路徑使用@和~的區(qū)別及說明

    這篇文章主要介紹了vue項目中路徑使用@和~的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue-router 起步步驟詳解

    vue-router 起步步驟詳解

    這篇文章主要介紹了vue-router 起步步驟詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • Vue數(shù)據(jù)更新視圖不更新的幾種解決方案小結(jié)

    Vue數(shù)據(jù)更新視圖不更新的幾種解決方案小結(jié)

    這篇文章主要介紹了Vue數(shù)據(jù)更新視圖不更新的幾種解決方案小結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評論