如何解決Vue請求接口出現(xiàn)跨域問題Access-Control-Allow-Origin
vue請求接口出現(xiàn)跨域問題
在使用axios請求了接口后,發(fā)現(xiàn)并沒有請求到,F(xiàn)12里面出現(xiàn)如下圖所示的報錯

這是提示跨域了。
所有使用JavaScript的瀏覽器都會支持同源策略。
同源策略即指域名/協(xié)議/端口號相同。
只要有一個不同,就會當(dāng)作跨域請求。
解決方法
一種是讓后端接口里添加如下兩句代碼:
header('Access-Control-Allow-Origin:*');//允許所有來源訪問
header('Access-Control-Allow-Method:POST,GET');//允許訪問的方式
當(dāng)然求人不如求己,自己在項目里面設(shè)置代理
- 如果使用vue-cli腳手架創(chuàng)建的項目,找到
config文件夾下的index.js文件。 - 找到
dev下的proxyTable {}
舉個例子:
如果請求接口為http://www.baidu.com/user/info/list,請求頭為http://www.baidu.com/,那么就添加
"/user": {
target: "http://www.baidu.com/",
changeOrigin: true,
}
然后找到請求頁面,在axios的請求接口里面只寫/user/info/list就行了。
更新: 另外一種配置方法:
同樣是更改config/index.js的配置文件:
module.exports = {
dev: {
proxyTable: {
'/api/: {
target: 'http://www.baidu.com/',
changeOrigin: true,
pathRewrire: {
'^/api': ''
}
}
}
}
上面的配置表示,遇到接口路徑有api的,就換成http://www.baidu.com/這個請求頭,同時把api去掉。
因為跨域問題一般只存在開發(fā)環(huán)境,所以我們可以把axios進(jìn)行如下配置:
if(process.env.NODE_ENV === 'production') {
axios.defaults.baseURL = '/'
} else {
axios.defaults.baseURL = '/api/'
}
這樣,我們在開發(fā)環(huán)境下,就可以通過增加api這個來配置跨域。
在Vue-cli3.0以上版本時
在項目根目錄下新建vue.config.js文件,在該文件內(nèi)新增如下配置:
module.exports = {
devServer: {
proxy: {
'/api': {
target: 'https://baidu.com',
ws: true,
changeOrigin: true,
pathRewrite: {
'^/api': ''
}
}
}
},
}
剩下的axios配置跟上面一樣,更多關(guān)于vue.config.js的配置文件請參考官方文檔吧
ok,就設(shè)置完成了,當(dāng)然最后一步千萬不要忘了:
關(guān)掉頁面,從新npm run dev一下,要不即使設(shè)置代理完成也會請求不到,一定要注意
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue3+Element-plus項目自動導(dǎo)入報錯的解決方案
vue3出來一段時間了,element也更新了版本去兼容vue3,下面這篇文章主要給大家介紹了關(guān)于Vue3+Element-plus項目自動導(dǎo)入報錯的解決方案,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
vue單向以及雙向數(shù)據(jù)綁定方式(v-bind和v-model的使用)
這篇文章主要介紹了vue單向以及雙向數(shù)據(jù)綁定方式(v-bind和v-model的使用),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
uniapp組件uni-file-picker中設(shè)置使用照相機(jī)和相冊權(quán)限的操作方法
這篇文章主要介紹了uniapp組件uni-file-picker中設(shè)置使用照相機(jī)和相冊的權(quán)限,在uniapp中,我們通常會使用uni-file-picker這個組件,但是這個組件中,有點缺陷,就是沒有對這個功能的傳值設(shè)置,這里就要給組件進(jìn)行修改了,需要的朋友可以參考下2022-11-11
VUEJS實戰(zhàn)之利用laypage插件實現(xiàn)分頁(3)
這篇文章主要為大家詳細(xì)介紹了VUEJS實戰(zhàn)之修復(fù)錯誤并且美化時間,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06

