vue-cli開發時,ajax跨域詳細解決辦法

NO IMAGE

目的:使用vue-cli構建的專案,在開發時,想要訪問後臺介面獲取資料,這時就會出現跨域問題。

在config/index.js中進行如下配置

【即在進行ajax請求時,地址中任何以/api開頭的請求地址都被解析為目標地址,target就是你想要的後臺介面地址】

proxyTable: {
‘/api’: {
target: ‘https://188.188.18.8‘,
changeOrigin: true,
pathRewrite: {
‘^/api’: ”
}
}
}

“`

vue-resource呼叫示例

this.$http.get('/api/v4/user/login', [options]).then(function(response){
// 響應成功回撥
}, function(response){
// 響應錯誤回撥
});

axios呼叫示例

  axios({
method: 'get',
headers: {'Accept': '*/*'},
url: '/api/v4/user/login',
data: options
})
.then(function (response) {
console.log(response.data)
})
.catch(function (error) {
console.log(error)
})

跨域原理(本地檔案假裝在遠端伺服器上):

通過瀏覽器開啟頁面,當發起請求時:本地伺服器的地址(通常是localhost:8080或者127.0.0.1:8080)會收到這個請求,接下來發現這個請求地址中含有字串 /api,那麼本地伺服器會將請求地址變為 https://188.188.18.8/v4/ (配置地址) user/login(呼叫方法處的詳細地址)
同時本地伺服器的地址會由localhost:8080 變為https://188.188.18.8/v4/,結果就是:
我們本地的檔案會被認為是放在目標地址(https://188.188.18.8/v4/)伺服器上的,當前伺服器上的檔案請求伺服器其他東西,自然就不是跨域了。