axios跨域和配置proxyTable

使用vue-axios和vue-resource解決vue中調(diào)用網(wǎng)易云接口跨域的問題

vue.js學(xué)習(xí)之 跨域請求代理與axios傳參

vue中proxyTable反向代理進(jìn)行跨域

奇怪的bug:解決 vue-cli中 proxyTable 配置無效

參考文檔https://vuejs-templates.github.io/webpack/proxy.html

本地開發(fā)服務(wù)下是 http://localhost:8080 這樣的訪問頁面,但是我們的接口地址是 http://xxxx.com/save/index 這樣的接口地址,我們這樣直接使用會存在跨域的請求,導(dǎo)致接口請求不成功,因此我們需要在打包的時候配置一下,我們進(jìn)入 config/index.js 代碼下如下配置即可:

dev: {

    // 靜態(tài)資源文件夾
    assetsSubDirectory: 'static',

    // 發(fā)布路徑
    assetsPublicPath: '/',
    // 代理配置表,在這里可以配置特定的請求代理到對應(yīng)的API接口
    // 例如將'localhost:8080/api/xxx'代理到'www.example.com/api/xxx'
    // 使用方法:https://vuejs-templates.github.io/webpack/proxy.html
    proxyTable: {
      '/api': {
        target: 'http://xxxxxx.com', // 接口的域名
        // secure: false,  // 如果是https接口,需要配置這個參數(shù)
        changeOrigin: true, // 如果接口跨域,需要進(jìn)行這個參數(shù)配置
        pathRewrite: {
          '^/api': ''
        }
      }
    },

注意: '/api' 為匹配項,target 為被請求的地址,因為在 ajax 的 url 中加了前綴 '/api',而原本的接口是沒有這個前綴的,所以需要通過 pathRewrite 來重寫地址,將前綴 '/api' 轉(zhuǎn)為 '/'。如果本身的接口地址就有 '/api' 這種通用前綴,就可以把 pathRewrite 刪掉。

配置多個路徑

proxyTable如何配置匹配所有路徑?

config中



發(fā)送請求時


注意! proxyTable 這個插件只限于開發(fā)模式下,后面一定要將前端代碼和服務(wù)器代碼部署到一起,否則需要要通過Nginx進(jìn)行跨域的轉(zhuǎn)發(fā)配置

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 今天我們畫了一張郵票,上面畫的是一只小狗,首先畫小狗的臉,小狗的臉像倒著的鴨梨一樣,然后從小狗的頭上畫一個眼鏡,然...
    明月_ca56閱讀 347評論 0 0

友情鏈接更多精彩內(nèi)容