Asp.net Core CORS(跨域資源共用)實驗

来源:https://www.cnblogs.com/lookerblue/archive/2018/02/28/8483033.html
-Advertisement-
Play Games

環境:Asp.Net Core 2 1、問題 最近項目在調用遠程UI時遇到點麻,在調用遠程CSS文件時無法載入其中的字體文件。遠程CSS文件對字體的定義: 瀏覽器沒有按照預想的那樣訪問到遠程字體資源並拋出了異常: 大意是CORS策略阻止了從http://localhost:2093訪問http:// ...


環境:Asp.Net Core 2

1、問題

最近項目在調用遠程UI時遇到點麻,在調用遠程CSS文件時無法載入其中的字體文件。遠程CSS文件對字體的定義:

@font-face {
    font-family: 'FontAwesome';
    src: url('../fonts/fontawesome-webfont.eot?v=4.7.0');
    …
}

瀏覽器沒有按照預想的那樣訪問到遠程字體資源並拋出了異常:

大意是CORS策略阻止了從http://localhost:2093訪問http://www.*/js/font-awesome/fonts/fontawesome-webfont.woff2?v=4.7.0中字體,請求資源沒有“Access-Control-Allow-Origin”報頭。

根據瀏覽器拋出的異常信息判斷,顯然是和CORS策略有關,第一時間想到的是Cors中間件。修改Startup.cs 將CORS策略設定為允許所有報頭,允許所有源地址,允許所有方法。

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    …
    app.UseCors(builder =>
        builder.AllowAnyHeader().AllowAnyOrigin().AllowAnyMethod());
    …
}

不幸的是上面策略並沒有影響結果,訪問遠程字體依然報錯。看來問題沒這麼簡單。問題是由CORS策略引起,也想趁此機會也補習一下CORS相關知識,為此設計了一個小實驗來加深對CORS的理解。

 

2、回顧CORS

網上已有很多文章專題介紹CORS,這裡不再贅述,可以參考:

http://www.cnblogs.com/artech/p/cors-4-asp-net-web-api-02.html

http://hbin.me/blog/2015/08/17/cross-origin-resource-sharing/

CORS基本規則是:

  • 請求報頭需要有Origin: http://www.foo.com,
  • 響應報頭需要有Access-Control-Allow-Origin: http://www.foo.com。

來看一下CORS完整工作流程圖:

第1步:瀏覽器向地址為http://localhost:1900的WebApp請求頁面;

第2步:WebApp返回Html頁面給瀏覽器;

第3步:瀏覽器解析頁面,確定跨域資源訪,瀏覽器按照CORS規則對跨域資源訪問請求進行封裝,在報頭添加Origin: http://localhost:1900等;

第4步:資源伺服器localhost:1800接收到請求,將收到的報頭與CORS策略進行比對。符合策略則返迴響應,響應報頭帶有Access-Control-Allow-Origin: http://localhost:1900,

最後瀏覽器收到響應,判斷報頭是否符合CORS策略,符合則顯示,不符合則阻止。

通過上面流程可以看出CORS依賴於瀏覽器,因為是瀏覽器負責判斷是否是跨域請求併進請求的行封裝,收到響應後也是瀏覽器判斷是否符合CORS規則併進行顯示。接下來通過一個實驗來看看瀏覽器在CORS中的作用。

 

 3、實驗

環境

服務端使用WebApi http://localhost:1800/api/values暴露一個服務,作為被訪問的資源。CORS策略為:

app.UseCors(builder => builder.WithOrigins("http://localhost:1900"));

準備四個不同的客戶端環境:

  1. WebApp1 http://localhost:1900/ 上使用ajax調用http://localhost:1800/api/values
  2. WebApp2 http://localhost:2000/ 上使用ajax調用http://localhost:1800/api/values
  3. WebApp3 http://localhost:2100/ 上使用HttpClient發起一個簡單請求調用http://localhost:1800/api/values
  4. 任意主機上安裝Postman

過程

首先我們在瀏覽器中分別訪問埠號為1900、2000、2100的三個Web地址,最後使用Postman直接調用遠程地址。

結果

WebApp1情況完全符合CORS策略,也得到了預計中的結果。

WebApp2由瀏覽器發起一個xhr,不符合策略因而被阻止。

WebApp3請求的發起是背後的HttpClient,並沒有通過瀏覽器。HttpClient發起請求時並有封裝CORS所需的信息,僅僅是一個簡單請求到http://localhost:1800/api/values,伺服器“如實”的返回了結果,需要註意的是此時伺服器CORS策略並沒有生效,HttpClient收到響應並把結果呈現在頁面上,整個過程都沒有CORS的影子。

最後使用Postman調用遠程地址,其原理與HttpClient訪問完全一樣。

 

4、小結

CORS策略只在瀏覽器+XHR的條件下才有效,它是瀏覽器與伺服器之間協調機制,不能當作安全機制使用。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 做了一個Winform的項目。項目里使用了WebBrowser控制項。以前一直都以為WebBrowser是直接調用的系統自帶的IE,IE是呈現出什麼樣的頁面WebBrowser就呈現出什麼樣的頁面。其實並非如此。我的Winform程式載入了一個Web項目。這個項目對IE8一下的瀏覽器佈局相容不是太好。 ...
  • 1 public void WriteData() 2 { 3 try 4 { 5 if (System.IO.Directory.Exists(DataFileRootPath) == false) 6 { 7 System.IO.Directory.CreateDirectory(DataFil ...
  • unity版本2017.2 不知道從那個版本起unity開始支持Google的webm格式了。這個格式可以支持帶有alpha通道的視頻,也就是透明視頻。 首先要製作透明視頻,在AE里可以導出帶有透明通道的視頻一般AVI和MOV都可以。 但是不知道為什麼轉換到webm會出錯,這個問題我以後可能會解決。 ...
  • 回到目錄 概念 ISoftDelete即軟刪除,數據在進行delete後不會從資料庫清除,而只是標記一個狀態,在業務範圍里都不能獲取到這個數據,這在ORM框架里還是比較容易實現的,對傳統的ado來說需要對sql統一進行攔截和條件過濾. 實施步驟 代碼實現 1 實體繼承ISoftDelete 2 數據 ...
  • 在16299支持在軟體自己重啟,不需要讓用戶點擊關閉然後啟動,雖然我還不知道這個有什麼用。本文告訴大家如何讓軟體關閉重新打開 ...
  • 概念總結:WebSerevice是一種跨編程語言和跨操作系統平臺的遠程調用技術傳輸協議:HTTP技術構成:XML+XSD,SOAP,WSDL XML封裝數據格式,解決數據表示問題 XSD定義一套數據類型標準 SOAP協議=HTTP協議+XML數據格式,SOAP提供了標準的RPC方法調用WebServ ...
  • 如果在vs擴展開發中出現 Failed to load Microsoft.VSSDK.BuildTools.15.0.26201\tools\VSSDK\bin\VSCT.exe' Assembly. 未能載入文件或程式集或它的某一個依賴項。系統找不到指定的文件 ...
  • 我現在有一個 100M 的代碼,需要快速去編譯他,我尋找了很多方法,本文記錄我找到的 IncrediBuild 用於提交編譯速度 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...