vue幾個(gè)常用跨域處理方式介紹
設(shè)置express代理請(qǐng)求
在基于vue-cli的項(xiàng)目中,在開(kāi)發(fā)環(huán)境配置(config/dev.env.js)中設(shè)置代理,能夠?qū)⑺?code>/apidomain開(kāi)頭的請(qǐng)求都通過(guò)npm run dev啟動(dòng)的express服務(wù)器重定向到目標(biāo)接口
官方文檔:https://vuejs-templates.github.io/webpack/proxy.html
proxyTable: {
'/apidomain':{
target:'http://localhost:prot',//或ip或域名。
changeOrigin:true,
pathRewrite: {
'^/apidomain': ''
}
}
},
若要通過(guò)IP在局域網(wǎng)訪問(wèn)h5,啟動(dòng)開(kāi)發(fā)服務(wù)器的時(shí)候添加host參數(shù)即可
即package.json的dev命令配置如下
"dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js --host 0.0.0.0",
關(guān)閉chrome安全策略實(shí)現(xiàn)跨域
windows中新建一個(gè)bat文件粘貼下面的命令即可以此模式打開(kāi)
cd "C:\Program Files (x86)\Google\Chrome\Application" chrome.exe --disable-web-security --user-data-dir=c:/CorsUserData
asp.net core 服務(wù)端的CORS跨域設(shè)置
官方文檔:https://docs.microsoft.com/zh-cn/aspnet/core/security/cors
在實(shí)際設(shè)置中,因?yàn)樵趆5端添加header參數(shù)產(chǎn)生了預(yù)檢(OPTIONS)請(qǐng)求,看了上述文章后將通用參數(shù)修改到了query參數(shù)中
1. 添加cors服務(wù)
public void ConfigureServices(IServiceCollection services)
{
//若只有部分接口則定義一個(gè)或多個(gè)命名的 CORS 策略,并在運(yùn)行時(shí)按名稱然后選擇的策略,通過(guò)特性標(biāo)記去設(shè)置跨域 詳情見(jiàn)文檔
services.AddCors();
}
2. 啟用中間件
//讀取配置文件中設(shè)置的允許跨域的域名 CorsOrigins為一個(gè)數(shù)組 設(shè)置["*"]則會(huì)允許所有
var origins = Configuration.GetSection("CorsOrigins").GetChildren().Select(s => s.Value).ToArray();
app.UseCors(e =>
{
e.WithOrigins(origins).AllowAnyHeader().AllowAnyMethod().AllowCredentials();
});
//Startup文件中Configuration對(duì)象的獲取
public IConfiguration Configuration { get; }
public Startup()
{
var builder = new ConfigurationBuilder()//...AddJsonFile($"appsettings.json");
Configuration = builder.Build();
}
JSONP
JSONP只支持GET請(qǐng)求,CORS支持所有類型的HTTP請(qǐng)求。JSONP的優(yōu)勢(shì)在于支持老式瀏覽器,以及可以向不支持CORS的網(wǎng)站請(qǐng)求數(shù)據(jù)。
相關(guān)文章
Vue3+elementui plus創(chuàng)建項(xiàng)目的方法
這篇文章主要介紹了Vue3+elementui plus創(chuàng)建項(xiàng)目的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
vuex 中輔助函數(shù)mapGetters的基本用法詳解
mapGetters輔助函數(shù)僅僅是將 store 中的 getter 映射到局部計(jì)算屬性,在組件或界面中不使用mapGetter調(diào)用映射vuex中的getter,在組件或界面中使用mapGetter調(diào)用映射vuex中的getter,具體內(nèi)容跟隨小編一起通過(guò)本文學(xué)習(xí)吧2021-07-07
vue刷新頁(yè)面時(shí)去閃爍提升用戶體驗(yàn)效果的實(shí)現(xiàn)方法
這篇文章主要介紹了vue刷新頁(yè)面時(shí)去閃爍提升體驗(yàn)方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-12-12
解決vue cli4升級(jí)sass-loader(v8)后報(bào)錯(cuò)問(wèn)題
這篇文章主要介紹了解決vue cli4升級(jí)sass-loader(v8)后報(bào)錯(cuò)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
vue-electron使用serialport時(shí)問(wèn)題解決方案
這篇文章主要介紹了vue-electron使用serialport時(shí)問(wèn)題解決方案,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
Vue?3?使用moment設(shè)置顯示時(shí)間格式的問(wèn)題及解決方法
在Vue?3中,因?yàn)檫^(guò)濾器(filter)已經(jīng)被廢棄,取而代之的是全局方法(global?method),本文給大家介紹Vue?3?使用moment設(shè)置顯示時(shí)間格式的問(wèn)題及解決方法,感興趣的朋友一起看看吧2023-12-12
web前端Vue報(bào)錯(cuò):Uncaught?(in?promise)?TypeError:Cannot?read?
這篇文章主要給大家介紹了關(guān)于web前端Vue報(bào)錯(cuò):Uncaught?(in?promise)?TypeError:Cannot?read?properties?of?nu的解決方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01
Vue中實(shí)現(xiàn)父子組件雙向數(shù)據(jù)流的三種方案分享
通常情況下,父子組件的通信都是單向的,或父組件使用props向子組件傳遞數(shù)據(jù),或子組件使用emit函數(shù)向父組件傳遞數(shù)據(jù),本文將嘗試講解Vue中常用的幾種雙向數(shù)據(jù)流的使用,需要的朋友可以參考下2023-08-08
VUE2實(shí)現(xiàn)事件驅(qū)動(dòng)彈窗示例
本篇文章主要介紹了VUE2實(shí)現(xiàn)事件驅(qū)動(dòng)彈窗示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10

