ASP.NET Core Web API 集成測試中使用 Bearer Token

来源:https://www.cnblogs.com/cgzl/archive/2018/07/23/9356596.html
-Advertisement-
Play Games

ASP.NET Core Web API 集成測試中使用 Bearer Token ...


在 ASP.NET Core Web API 集成測試一文中, 我介紹了ASP.NET Core Web API的集成測試. 

在那裡我使用了測試專用的Startup類, 裡面的配置和開發時有一些區別, 例如裡面去掉了用戶身份驗證相關的中間件.

但是有些被測試的行為裡面需要用到身份/授權信息.

所以本文就介紹一下在API集成測試中發送請求時使用Bearer Token作為Authorization Header的情況.

 

集成測試中使用Bearer Token

我這個項目里生產時使用的是Identity Server 4, 而進行集成測試時使用Identity Server 4可能會不太方便, 所以我決定簡化一下, 把這項工作就僅限制在API和測試項目這兩個項目里.

 

首先為被測試系統添加授權/身份驗證中間件, 修改StartupIntegrationTest:

在ConfigureServices()方法里, 首先添加一個許可權策略, 要求所有的MVC Controller只有授權的用戶才能訪問.

隨後使用AddAuthentication()添加身份驗證中間件, 並設置Bearer作為方案, 通過AddJwtBearer()進行一些參數配置.

這裡需要用到一個secret, 因為測試項目會用到, 所以暫時我把它弄成靜態屬性了.

最後在Configure()方法里使用該中間件即可.

 

來到集成測試項目的TestServerFixture類, 先要要做的就是使用上面的secret生成token, 併在HttpClient里設置Authorization Header即可:

生成token的代碼里可以設置Identity Claims. 這裡我只添加了Name和Role.

 

然後我們試試, 找一個集成測試進行調試, 我使用的是VSCode, 點擊方法上面的debug:

 

我在被測試方法里添加了一些傻代碼, 以便調試用戶信息:

查看Claims:

可以看到在測試代碼里設置了Identity Claims了, 說明使用Bearer Token成功了.

 

測試身份驗證中間件

被測試系統使用了身份中間件: app.UserAnthentication(), 我們也可以測試一下這個中間件的功能, 如果Token不正確的話, 就應該返回401 UnAuthorized狀態碼:

這個測試代碼很簡單, 就是設置了一個不正確的token, 並Assert返回狀態碼是401.

 

該測試會通過:

 

文章略短, 就介紹到這.

 


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

-Advertisement-
Play Games
更多相關文章
  • 互聯網這股東風不久前刮到了甘涼國,國王老甘獨具慧眼,想趕緊趁著東風未停大力發展移動互聯網,因為他篤信布斯雷的理論:“站在風口上,豬都能飛起來”。無奈地方偏僻落後,國內無可用之才啊。老甘一籌莫展的低頭凝思應聲被打斷,“啟奏陛下,有四個從東土大唐來的和尚前來更換通關文牒”,聽到“東土大唐”四個字,老甘心 ...
  • 因為IDEA和Goland來自同一家非常有名的捷克公司:JetBrains 很好用,智能化程度高 最新版下載地址:http://www.jetbrains.com/go/?fromMenu 相關使用手冊:https://www.jetbrains.com/help/go/discover-golan ...
  • 作者:freewind 比原項目倉庫: Github地址:https://github.com/Bytom/bytom Gitee地址:https://gitee.com/BytomBlockchain/bytom 在前一篇文章中,我們試圖理解比原是如何交易的,但是由於內容太多,我們把它分成了幾個小 ...
  • 作者:freewind 比原項目倉庫: Github地址:https://github.com/Bytom/bytom Gitee地址:https://gitee.com/BytomBlockchain/bytom 在比原的dashboard中,我們可以為一個帳戶創建地址(address),這樣就可 ...
  • 作者:freewind 比原項目倉庫: Github地址:https://github.com/Bytom/bytom Gitee地址:https://gitee.com/BytomBlockchain/bytom 在前面一篇文章,我們粗略的研究了一下比原的dashboard是如何做出來的,但是對里 ...
  • #include using namespace std; template class Person{ public: T age; public: explicit Person(T newAge); void show(); }; //類模版函數在外部定義時,必須加上template標識 te... ...
  • 1 sockaddr_in、sockaddr_in6和sockadd_un等都可以強制轉換為sockaddr. 2 IP地址是電分十進位形式的字元串,但是在網路中使用的是unsigned int類型的數才能使用。 3 函數listen, 第二個參數backlog,表示內核監聽隊列的最大長度,如果超過 ...
  • 一. SignalR中DI思想的應用 DI,即依賴註入,它是一種不負責創建其自己的依賴項對象的一種模式,通常用來降低代碼之間的耦合性,廣泛應用於架構設計,是必不可少的一種思想。 下麵結合一個需求來說一說SignalR中依賴註入思想的應用。 需求:比如在前面章節的聊天室案例中,想把發送的每條消息都記錄 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...