如何在中間件中多次讀取ASP.NET Core Response.Body?
ASP.NET Core 中介軟體多次讀取 Response.Body
概述
在 ASP.NET Core 中,多次存取回應流可能具有挑戰性。本文探討了預設 Response.Body 行為的局限性,並提供了一種在自訂中間件中讀取響應流的解決方案。
背景
在 ASP.NET Core 中,Response.Body 是一個只寫屬性,這表示它並非旨在在同一請求週期內從中讀取。這是框架效能最佳化的組成部分,但如果您需要多次存取回應流,則可能會帶來困難。
「臨時」解決方案:替換回應流
文中提到的解決方案似乎不是最佳的,因為它涉及用 MemoryStream 取代 Response.Body 流以進行讀取。這確實是一種有效的方法,儘管有點間接。
為 Response.Body 啟用緩衝
從 ASP.NET Core 2.1 開始,有一種更好的方法可以多次存取回應流:啟用緩衝。新的 Request.EnableBuffering() 方法可用於將回應流升級到 FileBufferingReadStream,後者支援查找和多次讀取。
更新後的中間件解決方案
將請求緩衝整合到中間件相對簡單。以下程式碼示範如何操作:
public class ResponseRewindMiddleware { private readonly RequestDelegate next; public ResponseRewindMiddleware(RequestDelegate next) { this.next = next; } public async Task Invoke(HttpContext context) { Stream originalBody = context.Response.Body; try { using (var memStream = new MemoryStream()) { context.Response.Body = memStream; await next(context); memStream.Position = 0; string responseBody = new StreamReader(memStream).ReadToEnd(); memStream.Position = 0; await memStream.CopyToAsync(originalBody); } } finally { context.Response.Body = originalBody; } } }
結論
替換 Response.Body 流可以作為一種在中間件中多次讀取響應流的可行方法。但是,首選方法是使用 Request.EnableBuffering() 啟用回應流上的緩衝。
以上是如何在中間件中多次讀取ASP.NET Core Response.Body?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

std::chrono在C 中用於處理時間,包括獲取當前時間、測量執行時間、操作時間點與持續時間及格式化解析時間。 1.獲取當前時間使用std::chrono::system_clock::now(),可轉換為可讀字符串但係統時鐘可能不單調;2.測量執行時間應使用std::chrono::steady_clock以確保單調性,並通過duration_cast轉換為毫秒、秒等單位;3.時間點(time_point)和持續時間(duration)可相互操作,但需注意單位兼容性和時鐘紀元(epoch)

在C 中,POD(PlainOldData)類型是指結構簡單且與C語言數據處理兼容的類型。它需滿足兩個條件:具有平凡的拷貝語義,可用memcpy複製;具有標準佈局,內存結構可預測。具體要求包括:所有非靜態成員為公有、無用戶定義構造函數或析構函數、無虛函數或基類、所有非靜態成員自身為POD。例如structPoint{intx;inty;}是POD。其用途包括二進制I/O、C互操作性、性能優化等。可通過std::is_pod檢查類型是否為POD,但C 11後更推薦用std::is_trivia

在C 中,將函數作為參數傳遞主要有三種方式:使用函數指針、std::function和Lambda表達式、以及模板泛型方式。 1.函數指針是最基礎的方式,適用於簡單場景或與C接口兼容的情況,但可讀性較差;2.std::function結合Lambda表達式是現代C 推薦的方式,支持多種可調用對象且類型安全;3.模板泛型方式最為靈活,適用於庫代碼或通用邏輯,但可能增加編譯時間和代碼體積。捕獲上下文的Lambda必須通過std::function或模板傳遞,不能直接轉換為函數指針。

AnullpointerinC isaspecialvalueindicatingthatapointerdoesnotpointtoanyvalidmemorylocation,anditisusedtosafelymanageandcheckpointersbeforedereferencing.1.BeforeC 11,0orNULLwasused,butnownullptrispreferredforclarityandtypesafety.2.Usingnullpointershe

使用OpenCV和C 進行圖像處理並不復雜,掌握基本流程和常用函數即可快速上手。 1.安裝與環境配置:確保正確安裝OpenCV,Linux可用包管理器,Windows可使用vcpkg或手動配置路徑,並通過簡單程序測試是否正常;2.圖像的基本操作:使用cv::imread()讀取、cv::imshow()顯示、cv::imwrite()保存圖像,並註意路徑判斷和waitKey()的必要性;3.常見圖像處理操作:包括灰度化、高斯模糊、Canny邊緣檢測和閾值處理,通常用於預處理階段;4.自定義卷積核

一個類成為抽像類的關鍵是它至少包含一個純虛函數。當類中聲明了純虛函數(如virtualvoiddoSomething()=0;),該類即成為抽像類,不能直接實例化對象,但可通過指針或引用實現多態;若派生類未實現所有純虛函數,則其也保持為抽像類。抽像類常用於定義接口或共享行為,例如在繪圖應用中設計Shape類並由Circle、Rectangle等派生類實現draw()方法。使用抽像類的場景包括:設計不應被直接實例化的基類、強制多個相關類遵循統一接口、提供默認行為的同時要求子類補充細節。此外,C

在C 中,mutable關鍵字用於允許修改對象的特定數據成員,即使該對像被聲明為const。其核心用途是保持對象邏輯上的常量性同時允許內部狀態變化,常見於緩存、調試計數器和線程同步原語。使用時需將mutable置於類定義中的數據成員前,僅適用於數據成員而非全局或局部變量。最佳實踐中應避免濫用、注意並發同步,並確保外部行為不變。例如std::shared_ptr用mutable管理引用計數以實現線程安全與const正確性。

在C 中生成UUID或GUID的有效方法有三種:1.使用Boost庫,提供多版本支持且接口簡潔;2.手動生成適用於簡單需求的Version4UUID;3.利用平台特定API(如Windows的CoCreateGuid),無需第三方依賴。 Boost適合大多數現代項目,手動實現適合輕量場景,平台API適合企業環境。
