.Net Core CORS跨域詳解及使用

一搜立、為什么會出現(xiàn)跨域問題

出于瀏覽器的同源策略限制棘街。同源策略(Sameoriginpolicy)是一種約定,它是瀏覽器最核心也最基本的安全功能移必,如果缺少了同源策略室谚,則瀏覽器的正常功能可能都會受到影響”苣可以說Web是構(gòu)建在同源策略基礎(chǔ)之上的舞萄,瀏覽器只是針對同源策略的一種實現(xiàn)。同源策略會阻止一個域的javascript腳本和另外一個域的內(nèi)容進(jìn)行交互管削。所謂同源(即指在同一個域)就是兩個頁面具有相同的協(xié)議(protocol)倒脓,主機(host)和端口號(port)

二、怎樣才算跨域

當(dāng)一個請求url的協(xié)議含思、域名崎弃、端口三者之間任意一個與當(dāng)前頁面url不同即為跨域

當(dāng)前頁面url 被請求頁面url 是否跨域 原因
http://www.test.com/ http://www.test.com/index.html 同源(協(xié)議甘晤、域名、端口號相同)
http://www.test.com/ https://www.test.com/index.html 跨域 協(xié)議不同(http/https)
http://www.test.com/ http://www.baidu.com/ 跨域 主域名不同(test/baidu)
http://www.test.com/ http://blog.test.com/ 跨域 子域名不同(www/blog)
http://www.test.com:8080/ http://www.test.com:7001/ 跨域 端口號不同(8080/7001)

三饲做、非同源限制

【1】無法讀取非同源網(wǎng)頁的 Cookie线婚、LocalStorage 和 IndexedDB

【2】無法接觸非同源網(wǎng)頁的 DOM

【3】無法向非同源地址發(fā)送 AJAX 請求

四、跨域解決方法

JSONP,CORS,Nginx等

這里主要講解的是 asp.net core
CORS解決方案

Startup中配置

ConfigureServices中注冊配置

public void ConfigureServices(IServiceCollection services)
{
    services.AddCors(c =>
    {

        //一般采用這種方法
        c.AddPolicy("LimitRequests", policy =>
        {
            // 支持多個域名端口盆均,注意端口號后不要帶/斜桿:比如localhost:8000/塞弊,是錯的
            // 注意,http://127.0.0.1:5401 和 http://localhost:5401 是不一樣的泪姨,盡量寫兩個
            policy
            .WithOrigins("http://127.0.0.1:5401","http://localhost:5401", "http://127.0.0.1:5402", "http://localhost:5402")
            .AllowAnyHeader()//允許任何標(biāo)頭
            .AllowAnyMethod();//允許任何方法
        });
    });
}

添加CORS中間件

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    app.UseCors("LimitRequests");//將 CORS 中間件添加到 web 應(yīng)用程序管線中, 以允許跨域請求游沿。
}

這樣就在asp.net core中完成了跨域請求的配置

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市肮砾,隨后出現(xiàn)的幾起案子诀黍,更是在濱河造成了極大的恐慌,老刑警劉巖仗处,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件眯勾,死亡現(xiàn)場離奇詭異,居然都是意外死亡婆誓,警方通過查閱死者的電腦和手機吃环,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來旷档,“玉大人模叙,你說我怎么就攤上這事⌒” “怎么了?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵故觅,是天一觀的道長厂庇。 經(jīng)常有香客問我,道長输吏,這世上最難降的妖魔是什么权旷? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮贯溅,結(jié)果婚禮上拄氯,老公的妹妹穿的比我還像新娘。我一直安慰自己它浅,他們只是感情好译柏,可當(dāng)我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著姐霍,像睡著了一般鄙麦。 火紅的嫁衣襯著肌膚如雪典唇。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天胯府,我揣著相機與錄音介衔,去河邊找鬼。 笑死骂因,一個胖子當(dāng)著我的面吹牛炎咖,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播寒波,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼乘盼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了影所?” 一聲冷哼從身側(cè)響起蹦肴,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎猴娩,沒想到半個月后阴幌,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡卷中,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年矛双,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蟆豫。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡议忽,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出十减,到底是詐尸還是另有隱情栈幸,我是刑警寧澤,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布帮辟,位于F島的核電站速址,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏由驹。R本人自食惡果不足惜芍锚,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蔓榄。 院中可真熱鬧并炮,春花似錦、人聲如沸甥郑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽壹若。三九已至嗅钻,卻和暖如春皂冰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背养篓。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工秃流, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人柳弄。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓舶胀,卻偏偏與公主長得像,于是被迫代替她去往敵國和親碧注。 傳聞我的和親對象是個殘疾皇子嚣伐,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 什么是跨域 跨域,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本萍丐。它是由瀏覽器的同源策略造成的轩端,是瀏覽器對JavaScript實...
    Yaoxue9閱讀 1,299評論 0 6
  • 什么是跨域 跨域,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本逝变。它是由瀏覽器的同源策略造成的基茵,是瀏覽器對JavaScript實...
    他方l閱讀 1,064評論 0 2
  • 題目1.什么是同源策略? 同源策略(Same origin Policy): 瀏覽器出于安全方面的考慮,只允許與本...
    FLYSASA閱讀 1,721評論 0 6
  • 什么是跨域 跨域壳影,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本拱层。它是由瀏覽器的同源策略造成的,是瀏覽器對JavaScript實...
    HeroXin閱讀 836評論 0 4
  • 1. 什么是跨域 跨域宴咧,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本根灯。它是由瀏覽器的同源策略造成的,是瀏覽器對JavaScri...
    cbw100閱讀 6,330評論 2 86