如何解決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-07vue單向以及雙向數(shù)據(jù)綁定方式(v-bind和v-model的使用)
這篇文章主要介紹了vue單向以及雙向數(shù)據(jù)綁定方式(v-bind和v-model的使用),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04uniapp組件uni-file-picker中設(shè)置使用照相機(jī)和相冊權(quán)限的操作方法
這篇文章主要介紹了uniapp組件uni-file-picker中設(shè)置使用照相機(jī)和相冊的權(quán)限,在uniapp中,我們通常會使用uni-file-picker這個組件,但是這個組件中,有點(diǎn)缺陷,就是沒有對這個功能的傳值設(shè)置,這里就要給組件進(jìn)行修改了,需要的朋友可以參考下2022-11-11VUEJS實戰(zhàn)之利用laypage插件實現(xiàn)分頁(3)
這篇文章主要為大家詳細(xì)介紹了VUEJS實戰(zhàn)之修復(fù)錯誤并且美化時間,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06