ASP.NET WEBAPI 的身份驗證和授權

来源:http://www.cnblogs.com/dongbeifeng/archive/2016/07/28/authentication-and-authorization-in-aspnet-web-api.html
-Advertisement-
Play Games

定義 身份驗證(Authentication):確定用戶是誰。 授權(Authorization):確定用戶能做什麼,不能做什麼。 身份驗證 WebApi 假定身份驗證發生在宿主程式稱中。對於 web-hosting,宿主是 IIS。這種情況下使用 HTTP Module 進行驗證。 驗證時,宿主會 ...


定義

身份驗證(Authentication):確定用戶是誰。

授權(Authorization):確定用戶能做什麼,不能做什麼。

身份驗證

WebApi 假定身份驗證發生在宿主程式稱中。對於 web-hosting,宿主是 IIS。這種情況下使用 HTTP Module 進行驗證。

驗證時,宿主會創建一個表示安全上下文的主體對象(實現 IPrincipal),將它附加到當前線程。主體對象包含一個存儲用戶信息的 Identity 對象。若驗證成功,Identity.IsAuthenticated 屬性將返回 true。

HTTP 消息處理程式(HTTP Message Handler)

可以用 HTTP 消息處理程式代替宿主進行身份驗證。這種情況下,由 HTTP 消息處理程式檢查請求並設置主體對象。

請考慮以下事項決定是否使用消息處理程式進行身份驗證:

  • HTTP 模塊檢查所有經過 asp.net 管道的請求,消息處理程式只檢查路由到 WebAPI的請求。
  • 可以為每個路由單獨設置消息處理程式。
  • HTTP 模塊僅在 IIS 中可用。消息處理程式則與宿主無關,在 web-hosting 和 self-hosting 中均可用。
  • HTTP 模塊參與IIS 日誌和審計等功能。
  • HTTP模塊在管道之前運行,主體在消息處理程式運行之前不會設置,當響應離開 消息處理程式時,主體會恢覆成原來的那個。

一般來說,不需要自承載時,HTTP 模塊較好。

設置主體

進行自定義身份驗證時,應在兩個地方設置主體對象:

  • Thread.CurrentPrincipal,這是 .net 中設置線程主體的標準方式。
  • HttpContext.Current.User 這是特定於 ASP.NET 的屬性。
private void SetPrincipal(IPrincipal principal)
{
    Thread.CurrentPrincipal = principal;
    if (HttpContext.Current != null)
    {
        HttpContext.Current.User = principal;
    }
}

採用 web-hosting 時,必須同時設置兩處,避免安全上下文不一致。對於 self-hosting,HttpContext.Current 為 null,所以設置之前應進行檢查。

授權

授權發生在管道中更接近 controller 的位置。

  • 授權篩選器(Authorization filter)在 action 之前運行。若請求未授權,返回錯誤,action 不運行。
  • 在 action 內部,可以用 ApiController.User 屬性獲取主體對象,做進一步的控制。

[Authorize] 屬性

AuthorizeAttribute 是內置的授權篩選器。用戶未通過身份驗證時,它返回 HTTP 401 狀態碼。可以在全局,控制和 action 三個級別應用它。

在全局級別應用

public static void Register(HttpConfiguration config)
{
    config.Filters.Add(new AuthorizeAttribute());
}

在控制器級別應用

[Authorize]
public class ValuesController : ApiController
{
    public HttpResponseMessage Get(int id) { ... }
    public HttpResponseMessage Post() { ... }
}

在 Action 級別應用

public class ValuesController : ApiController
{
    public HttpResponseMessage Get() { ... }
    
    [Authorize]
    public HttpResponseMessage Post() { ... }
}

在控制器上應用 [Authorize] 時,可以在 Action 上應用 [AllowAnonymous] 取消對某個 Action 的授權要求。上面的代碼可以改成下麵的形式:

[Authorize]
public class ValuesController : ApiController
{
    [AllowAnonymous]
    public HttpResponseMessage Get() { ... }

    public HttpResponseMessage Post() { ... }
}

指定用戶和角色進行限制:

// 按用戶限制訪問
[Authorize(Users="Alice,Bob")]
public class ValuesController : ApiController
{
}
   
// 按角色限制訪問
[Authorize(Roles="Administrators")]
public class ValuesController : ApiController
{
}

用於 WebAPI 的 AuthorizeAttribute 位於 System.Web.Http 命名空間。在 System.Web.Mvc 命名空間中有一個同名屬性,不可用於 WebAPI。

自定義授權篩選器

可從以下類型派生自定義授權篩選器

  • AuthorizeAttribute,基於用戶和角色進行授權。
  • AuthorizationFilterAttribute,不基於用戶和角色的同步授權。
  • IAuthorizationFilter,實現此介面執行非同步授權邏輯。例如,授權邏輯中有對 IO 或網路的非同步調用。(CPU-bound的授權邏輯更適合從 AuthorizationFilterAttribute 派生,這樣不必寫非同步方法)。

下圖是 AuthorizeAttribute 類層次

在 Action 中執行驗證

可在控制器中檢查 ApiController.User 屬性,根據用戶和角色使用不同的邏輯。

public HttpResponseMessage Get()
{
    if (User.IsInRole("Administrators"))
    {
        // ...
    }
}

 

原文地址:http://www.asp.net/web-api/overview/security/authentication-and-authorization-in-aspnet-web-api

 


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

-Advertisement-
Play Games
更多相關文章
  • 1、算術運算符 常見的算術運算符 2、邏輯運算符 PHP中的邏輯運算符 3、賦值運算符 賦值運算符“=”是PHP中最基本的運算符,即把“=”右邊表達式的值賦給左邊的運算數。 另外PHP中也常用到複合賦值運算符。 複合賦值運算符 4、比較運算符 ...
  • Luence 是Apache軟體基金會的一個項目,是一個開發源碼的全文檢索引擎工具包,是一個全文檢索引擎的一個架構。提供了完成的查詢引擎和檢索引擎,部分文本分析引擎。 全文檢索程式庫,雖然與搜索引擎相關,但是不能混淆。 官方網址:https://lucene.apache.org/ 幫助文檔:htt ...
  • 摘要:本文來自Nginx官方博客,是微服務系列文章的第一篇,主要探討了傳統的單體式應用的不足,以及微服務架構的優勢與挑戰。正如作者所說,微服務架構更適合用於構建複雜的應用,儘管它也有自己的不足。 這篇文章作者是Chris Richardson,他是早期基於Java的Amazonite EC2 Paa ...
  • 一行代碼解決各種IE相容問題,IE6,IE7,IE8,IE9,IE10 ...
  • 閑來無事用Python寫了一個簡陋的埠掃描腳本,其簡單的邏輯如下: 1. python DetectHostPort.py iplist.txt(存放著需要掃描的IP地址列表的文本,每行一個地址) 2. 輸入掃描埠、掃描時間和掃描間隔。 3. 輸出掃描信息。 下麵貼上源碼,歡迎拍磚。 這個腳本有 ...
  • 1、下載smarty模板,官方即有 2、解壓即可、你會得這樣的目錄 除了libs文件夾其餘都可以刪掉(不知道有啥用)。 3、在當前目錄下分別創建templates、templates_c、cache、config的文件夾,別的名字也可以,但是需要修改配置文件 4、在根目錄下創建個文件夾叫啥都行,創建 ...
  • Delphi Berlin 10.1 開發 Windows 10 平板 App 遠程調試安裝步驟: 準備電腦: 準備電腦: 設定環境: 設定環境: 遠程調試(連結遠端平板電腦): 遠程調試(連結遠端平板電腦): 中斷連結平板電腦: 中斷連結平板電腦: ...
  • server: client: ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...