日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

ASP.NET Web API自身对CORS的支持: CORS授权检验的实施

發布時間:2025/3/18 asp.net 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ASP.NET Web API自身对CORS的支持: CORS授权检验的实施 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

通過《EnableCorsAttribute特性背后的故事》我們知道:由CorsPolicyProvider提供的CorsPolicy表示目標Action采用的資源授權策略,ASP.NET Web API最終需要利用它對具體的跨域資源請求實施授權檢驗并生成相應的CORS響應報頭。在ASP.NET Web API的應用編程接口中,資源授權檢驗的結果通過類型CorsResult來表示。

一、CorsResult

CorsResult定義在命名空間“System.Web.Cors”下,表示資源提供者針對具體跨域資源請求進行授權檢驗得到的結果,最終寫入響應的CORS報頭均通過此對象來生成。如下面的代碼片斷所示,CorsResult依然具有與6個CORS響應報頭對應的屬性,通過其方法ToResponseHeaders方法的字典表示由此6個屬性生成的CORS相應報頭,字典對象的Key和Value分別表示報頭名稱和值。

1: public class CorsResult 2: { 3: public string AllowedOrigin { get; set; } 4: public IList<string> AllowedExposedHeaders { get; } 5: public IList<string> AllowedHeaders { get; } 6: public IList<string> AllowedMethods { get; } 7: public long? PreflightMaxAge { get; set; } 8: public bool SupportsCredentials { get; set; } 9: 10: public IList<string> ErrorMessages { get; } 11: public bool IsValid { get; } 12:? 13: public virtual IDictionary<string, string> ToResponseHeaders(); 14: }

CorsResult具有一個布爾類型的屬性IsValid表示請求是否通過資源授權檢驗。如果該屬性返回False(沒有通過資源授權檢驗),另一個相關的屬性ErrorMessages會提供導致檢驗失敗的原因。IsValid是一個只讀屬性,它的值取決于通過ErrorMessages屬性表示的字符串列表是否為空。

二、CorsRequestContext

針對CORS的支持其實并不限于僅被使用在ASP.NET Web API上,用于根據提供的資源授權策略對跨域資源請求進行授權檢驗得引擎定義在程序集System.Web.Cors.dll中,定義在另一個程序集對于這些類型來說,除了CorsPolicy定義在程序集System.Web.Cors.dll,其余的類型均定義在程序集System.Web.Http.Cors.dll中的相關類型可以視為對這個核心CORS引擎的擴展。對于本節引入的類型來說,它具有的命名空間其實也體現了它所在的程序集。

對于ASP.NET Web API來說,CORS資源授權檢驗實施的目標是表示當請求的HttpRequestMessage對象,這個對象自然不可能使用在ASP.NET的核心CORS引擎中。對于后者,授權檢驗是針對一個System.Web.Cors.CorsRequestContext對象,它代表針對當前請求的上下文。如下面的代碼片斷所示,我們可以通過CorsRequestContext對象得到對應HTTP請求的地址(RequestUri)、主機名稱(Host)和采用的HTTP方法(HttpMethod)。

1: public class CorsRequestContext 2: { 3: public Uri RequestUri { get; set; } 4: public string Host { get; set; } 5: public string HttpMethod { get; set; } 6: 7: public string Origin { get; set; } 8: public bool IsPreflight { get; } 9: public string AccessControlRequestMethod { get; set; } 10: public ISet<string> AccessControlRequestHeaders { get; } 11:? 12: public IDictionary<string, object> Properties { get; } 13: }

CorsRequestContext的Origin屬性返回通過請求的“Origin”報頭表示的源站點。我們可以利用其IsPreflight屬性判斷HTTP請求是否為一個預檢請求,這里對預檢請求的判斷標準與我們前面演示實例采用的完全一致:采用HTTP-OPTIONS方法摒棄同時具有“Origin”和“Access-Control-Request-Method”報頭。

對于針對預檢請求的CorsRequestContext,我們可以通過其屬性AccessControlRequestMethod和AccessControlRequestHeaders得到請求報頭“Access-Control-Request-Method”和“Access-Control-Request-Headers”的值。通過另一個字典類型的只讀屬性Properties,我們可以將任意對象作為屬性附加到該CorsRequestContext對象上。

三、CorsEngine

我們說ASP.NET 的核心CORS引擎定義在程序集System.Web.Cors.dll中,它主要體驗為這個名為CorsEngine的對象,其主要的使命在于:根據提供的資源授權策略(通過CorsPolicy類型表示)針對具體的跨域資源請求(通過CorsRequestContext類型表示)實施授權檢驗并得到相應的授權結果(通過CorsResult表示)。所有的CorsEngine類型均實現System.Web.Cors.ICorsEngine接口,如下面的代碼片斷所示,跨域資源請求的授權檢查就實現在其唯一的EvaluatePolicy方法中。

1: public interface ICorsEngine 2: { 3: CorsResult EvaluatePolicy(CorsRequestContext requestContext, CorsPolicy policy); 4: }

在程序集System.Web.Cors.dll中定義了唯一的實現了ICorsEngine接口,即具有如下定義的類型System.Web.Cors.CorsEngine。如下面的代碼片斷所示,CorsEngine類型定義了3個輔助的虛方法(TryValidateOrigin、TryValidateMethod 和TryValidateHeaders)分別針對請求的源站點以及請求采用的HTTP方法和自定義報頭實施授權檢驗,其中后面兩個方法是專門為預檢請求設計的。

1: public class CorsEngine : ICorsEngine 2: { 3: public virtual CorsResult EvaluatePolicy(CorsRequestContext requestContext, CorsPolicy policy); 4:? 5: public virtual bool TryValidateOrigin(CorsRequestContext requestContext, CorsPolicy policy, CorsResult result); 6: public virtual bool TryValidateMethod(CorsRequestContext requestContext, CorsPolicy policy, CorsResult result); 7: public virtual bool TryValidateHeaders(CorsRequestContext requestContext, CorsPolicy policy, CorsResult result); 8: }

CorsPolicyProviderFactory一樣,ASP.NET Web API使用的CorsEngine需要注冊到當前HttpConfiguration,注冊的CorsEngine同樣是被添加到HttpConfiguration的屬性字典之中。CorsEngine的注冊可以通過調用HttpConfiguration如下所示的擴展方法SetCorsEngine來完成。另一個擴展方法GetCorsEngine用于獲取注冊的CorsEngine,如果在調用此方法時CorsEngine尚未被注冊,一個CorsEngine對象會被創建出來并自動注冊到HttpConfiguration上。

1: public static class CorsHttpConfigurationExtensions 2: { 3: //其他成員 4: public static void SetCorsEngine(this HttpConfiguration httpConfiguration, ICorsEngine corsEngine); 5: public static ICorsEngine GetCorsEngine(this HttpConfiguration httpConfiguration); 6: }

?

CORS系列文章
[1] 同源策略與JSONP
[2] 利用擴展讓ASP.NET Web API支持JSONP
[3] W3C的CORS規范
[4] 利用擴展讓ASP.NET Web API支持CORS
[5] ASP.NET Web API自身對CORS的支持: 從實例開始
[6] ASP.NET Web API自身對CORS的支持: CORS授權策略的定義和提供
[7] ASP.NET Web API自身對CORS的支持: CORS授權檢驗的實施
[8] ASP.NET Web API自身對CORS的支持: CorsMessageHandler


作者:蔣金楠
微信公眾賬號:大內老A
微博:www.weibo.com/artech
如果你想及時得到個人撰寫文章以及著作的消息推送,或者想看看個人推薦的技術資料,可以掃描左邊二維碼(或者長按識別二維碼)關注個人公眾號(原來公眾帳號蔣金楠的自媒體將會停用)。
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。 原文鏈接

總結

以上是生活随笔為你收集整理的ASP.NET Web API自身对CORS的支持: CORS授权检验的实施的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲女人18毛片水真多 | 激情视频一区二区 | 国产女人叫床高潮大片免费 | 97色吧| 亚洲爽爽 | 国产又爽又黄游戏 | 日韩欧美在线观看视频 | 高h调教冰块play男男双性文 | 色偷偷中文字幕 | 久久久久久久色 | h片网站在线观看 | 亚洲AV无码成人精品国产一区 | 午夜天堂av| 亚洲激情视频小说 | 精品视频一区在线观看 | 久操视频免费 | 麻豆导航 | 欧美性生活网址 | 中国吞精videos露脸 | 午夜做爰xxxⅹ性高湖视频美国 | 亚洲欧美自拍视频 | 国产图片区 | 无码人妻丰满熟妇区五十路百度 | 国产天堂av | 少妇做爰免费视看片 | 欧美精品一区二区三区在线 | 激情偷拍| 聚色av| 国产一区二区精品丝袜 | 制服丝袜第一页在线观看 | 日本少妇xxxxx | jizz日本在线 | 91视频在线观看网站 | 国产乱人乱精一区二视频国产精品 | 日本阿v视频 | 一极黄色大片 | 91自啪| 少妇精品高潮欲妇又嫩中文字幕 | 污污视频在线 | 亚洲精品成人在线 | 国产精品国产三级国产 | 欧美日韩一区二区在线 | 日本三级一区二区三区 | 姑娘第5集在线观看免费好剧 | 成人在线一区二区三区 | 综合久久久久 | 黑人巨大精品欧美一区二区免费 | 国产无套在线观看 | 欧美巨鞭大战丰满少妇 | 人妻熟人中文字幕一区二区 | 日本h在线观看 | 一本一道久久综合狠狠老精东影业 | 国产午夜精品福利视频 | 国产又黄视频 | 美女裸体跪姿扒开屁股无内裤 | 日韩av男人天堂 | 第色| 午夜视频久久 | 特级毛片在线 | 国产精品久久久久精 | 比利时xxxx性hd极品 | www,五月天,com | 91亚洲精品一区二区乱码 | 私人网站 | 日韩小视频网站 | 亚洲视频综合 | 8050午夜一级毛片久久亚洲欧 | 在线日韩一区二区 | 怡红院男人天堂 | 波多野结衣理论片 | 337p粉嫩大胆噜噜噜亚瑟影院 | 乌克兰少妇性做爰 | 午夜精品久久久久久久久 | 四虎成人精品在永久免费 | 2025中文字幕 | 老熟女重囗味hdxx69 | 免费观看av网站 | 国产精品视频a | 国产精品无码久久av | 久久色视频 | 亚洲一区二区三区蜜桃 | 天天爽夜夜操 | 国产一区视频在线免费观看 | 在线播放不卡av | 欧美日韩在线直播 | 91人人澡人人爽人人精品 | 波多野结衣久久 | 亚洲欧美另类图片 | 黄色在线免费观看网站 | 亚洲欧洲一区 | 国产熟女一区二区三区五月婷 | 在线精品视频免费观看 | 羞羞的视频网站 | 色小姐av| 看了下面会湿的视频 | 涩涩五月天 | 深夜视频在线观看免费 | 美女一区二区三区视频 | 日韩视频一区二区三区四区 |