CORS FOR AspNetCore

来源:https://www.cnblogs.com/wellsyu/archive/2017/12/30/8146499.html
-Advertisement-
Play Games

廢話: 以前總是看別人博客,但是連評論都懶得給一個,於是心有愧疚,開始寫寫東西。本人不是科班出生的CODER,只是看多了,懂一些,瞭解一些思想,也不會動手CODING,也就把看到的換種話記錄下來。最近瞭解了一下asp.net core 的pipeline,認識了CORS,這篇文章就是把關於CORS的 ...


廢話:

以前總是看別人博客,但是連評論都懶得給一個,於是心有愧疚,開始寫寫東西。本人不是科班出生的CODER,只是看多了,懂一些,瞭解一些思想,也不會動手CODING,也就把看到的換種話記錄下來。最近瞭解了一下asp.net core 的pipeline,認識了CORS,這篇文章就是把關於CORS的Microsoft知識文檔用自己的話翻譯一下。

正文:

參考:

https://docs.microsoft.com/en-us/aspnet/core/security/cors

 

 CORS(Cross Origin Resource Sharing),是一種跨域資源共用方式,由於瀏覽器“same-origin"(同源同策)的限制,其在實際應用中產生,同是W3C標準

至於何為SAME-ORIGIN:

  1. 協議相同,比如http、https、file等
  2. 域相同,比如www.baiud.com
  3. 埠相同

 

如何使用CORS

使用方法一:全局應用

.net core 的CORS模塊位於Microsoft.AspNetCore.Cors的nuget包

在asp.net core 中的services和middleware配置CORS

添加引用:

using Microsoft.AspNetCore.Cors

 

startup.cs

public void ConfigurationServices(IserviceCollection services)
{
    services.AddCors()
}
public void Configure(IApplicationBuilder app,IHostingEnviroment env,ILoggerFactory loggerFactory)
{
  app.UseCors(builder=>
    builder.WithOrigins("http://localhost:5000”);
  );
}

 

 註意:

  1. AddCors()優先於其他任何服務
  2. builder.WithOrigins(url)的參數不能以‘/’結尾
  3. builder有一些chain method ,是用於過濾請求的,可自行查閱

 

使用方法二:命名使用

先定義一個或多個CORS策略,在controller、class、function等對象上根據策略名字,在attribute中使用

 

startup.cs

public void ConfigureServices(IServiceCollection services)
{
    services.AddCors(options =>
    {
        options.AddPolicy("AllowAOrigin",
            builder => builder.WithOrigins("http://example.com"));

        options.AddPolicy("AllowBOrigin",
            builder => builder.WithOrigins("http://example.com"))

  }); 
} 

public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory) 
{ 
  app.UseCors("AllowAOrigin");
}

//如果是MVC APP,只需要add service,不需要配置middleware

在attribute中使用CORS

[HttpGet]
[EnableCors("AllowSpecificOrigin")]
public IEnumerable<string> Get()
{
    return new string[] { "value1", "value2" };
}

 限制所有controller

public void ConfigureServices(IServiceCollection services)
{
    services.AddMvc();
    services.Configure<MvcOptions>(options =>
    {
        options.Filters.Add(new CorsAuthorizationFilterFactory("AllowAOrigin"));
    });
}

 到這裡CORS基本用法差不多了,細節之處可見官網文檔,英語好的可以自行看英文文檔.至於這個東西在實際什麼項目中怎麼應用我也不清楚,不過我用在分離前後端上倒是好用。


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

-Advertisement-
Play Games
更多相關文章
  • 都線上購物過吧?那麼你應該體驗過,當沒有登錄賬戶時,點開購物車,個人中心,收藏物品等的操作時,都會直接跳轉到登錄賬戶的界面,然後如果登錄一次後就不用再登錄,直到用戶登出。 是的,本次項目就是做一個登錄驗證系統 需求:1.模擬某購物網站,進入菜單選項:一共有以下頁面,根據用戶輸入的序號,做出不同的反饋 ...
  • 2.1 python3.6 工具使用 運行python 自帶的idle後,輸入python命令,如print('hello world'),回車後輸出 hello world 其中mac系統會出現一段warning :the version of tcl/tk in use may be ustab ...
  • 最近項目用到springcloud,研究了下springcloud的熔斷機制Hystrix。 熔斷機制,就是下游服務出現問題後,為保證整個系統正常運行下去,而提供一種降級服務的機制,通過返回緩存數據或者既定數據,避免出現系統整體雪崩效應。在springcloud中,該功能可通過配置的方式加入到項目中 ...
  • 用正則表達式開發一個計算器,計算用戶給定的一串帶有加減乘除的公式。 要求:不能使用eval轉換字元串 分析: 要求簡單,就是計算混合運算,但是不能使用eval直接轉換,主要就是把整個式子中的小括弧優先匹配到進行計算再把計算結果替換到式子中,然後再根據小括弧計算,直到沒有小括弧再按照加減乘除優先順序計算 ...
  • 實現簡單的登錄和註冊 步驟: 工程目錄: 1.創建一個動態的web工程 2.導入springMvc所需要的jar包(包含mysql驅動包) 3.配置web.xml步驟: 配置唯一的 Servlet 3.1 增加 servlet和 servlet-mapping 標簽 3.2 配置 servlet 標 ...
  • 昨天同事說微信更新有跳一跳小游戲,便更新了玩一玩。至於抄襲不抄襲我不討論,看玩法和色彩都很簡潔。想用Python試試攝像頭捕捉圖像,然後分析距離每次都能跳到中心,有生物機械手指之類的再弄到樹莓派上豈不是能玩最高分啦。 心路歷程 環境是windows,安裝opencv 需要其他包的可另行下載。 hel ...
  • 1、面向對象的特征有哪些方面? 【基礎】 答:面向對象的特征主要有以下幾個方面: 1)抽象:抽象就是忽略一個主題中與當前目標無關的那些方面,以便更充分地註意與當前目標有關的方面。抽象並不打算瞭解全部問題,而只是選擇其中的一部分,暫時不用部分細節。抽象包括兩個方面,一是過程抽象,二是數據抽象。 2)繼 ...
  • 創建一個文本文件,文本寫至這個文件里。 class Bu { public string fileName { get; set; } = "hello.txt"; public string filecontent { get; set; } public void WriteText2File( ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...