使用vue-axios和vue-resource解決vue中調(diào)用網(wǎng)易云接口跨域的問題
vue.js學習之 跨域請求代理與axios傳參
vue中proxyTable反向代理進行跨域
奇怪的bug:解決 vue-cli中 proxyTable 配置無效
參考文檔https://vuejs-templates.github.io/webpack/proxy.html
本地開發(fā)服務下是 http://localhost:8080 這樣的訪問頁面,但是我們的接口地址是 http://xxxx.com/save/index 這樣的接口地址幕与,我們這樣直接使用會存在跨域的請求,導致接口請求不成功,因此我們需要在打包的時候配置一下,我們進入 config/index.js 代碼下如下配置即可:
dev: {
// 靜態(tài)資源文件夾
assetsSubDirectory: 'static',
// 發(fā)布路徑
assetsPublicPath: '/',
// 代理配置表羹与,在這里可以配置特定的請求代理到對應的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, // 如果接口跨域,需要進行這個參數(shù)配置
pathRewrite: {
'^/api': ''
}
}
},
注意: '/api' 為匹配項冠摄,target 為被請求的地址糯崎,因為在 ajax 的 url 中加了前綴 '/api',而原本的接口是沒有這個前綴的河泳,所以需要通過 pathRewrite 來重寫地址沃呢,將前綴 '/api' 轉為 '/'。如果本身的接口地址就有 '/api' 這種通用前綴拆挥,就可以把 pathRewrite 刪掉薄霜。
配置多個路徑
proxyTable如何配置匹配所有路徑?
config中
發(fā)送請求時
注意纸兔! proxyTable 這個插件只限于開發(fā)模式下惰瓜,后面一定要將前端代碼和服務器代碼部署到一起,否則需要要通過Nginx進行跨域的轉發(fā)配置