在 ASP.NET Core 中使用 HTTP 标头传播
前言
我們常用 JWT 令牌用于身份驗證,前端一般是在請求中包含 HTTP 標頭?Authorization?實現。
但是,當服務間需要互相調用時,也需要"按原樣"將標頭傳播到目標服務。
原來的解決方案是從請求中讀取標頭,并將其添加到對外請求標頭集合中。
后來發現,微軟已經考慮了這種場景,并提供了專門的中間件來解決這個需求。
Demo
下面,我們創建 ServerA、ServiceB 兩個 Web API 項目來演示這一功能。
首先,ServiceB 有一個 GET 方法,返回在請求中收到的所有標頭,這使我們能夠驗證標頭是否被傳播:
[HttpGet] public?IHeaderDictionary?Get() {return?Request.Headers; }執行 ServiceB 的 GET 請求,我們可以類似下圖的響應:
現在,用 ServiceA 調用 ServiceB 并返回響應。這將向我們顯示哪些標頭傳播到 ServiceB:
[HttpGet] public?async?Task<string>?Get() {var?client?=?_clientFactory.CreateClient("ServiceB-Client");var?response?=??await?client.GetAsync("/ServiceB");return?await?response.Content.ReadAsStringAsync(); }執行 ServerA 的 GET 請求,可以看到,Authorization?標頭并沒有被傳播:
這時,我們可以引用 Nuget 包?Microsoft.AspNetCore.HeaderPropagation,并且修改 Startup.cs 啟用標頭傳播功能:
public?void?ConfigureServices(IServiceCollection?services) {//?定義需要傳播的標頭services.AddHeaderPropagation(options?=>?options.Headers.Add("Authorization"));services.AddHttpClient("ServiceB-Client",?options?=>?options.BaseAddress?=?new?Uri("http://localhost:57516"))//?定義開啟標頭傳播.AddHeaderPropagation();...... }public?void?Configure(IApplicationBuilder?app,?IWebHostEnvironment?env) {//?添加標頭傳播middlewareapp.UseHeaderPropagation();...... }再次執行 ServerA 的 GET 請求,可以看到,Authorization?標頭被正確傳播了:
結論
標頭傳播中間件允許我們輕松地將標頭從一個請求傳播到另一個請求。
可用于下列場景:
授權令牌
語言選擇
分布式跟蹤請求鏈
瀏覽器信息
其他自定義信息
想了解更多內容,請關注我的個人公眾號”My IO“
總結
以上是生活随笔為你收集整理的在 ASP.NET Core 中使用 HTTP 标头传播的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: XElement 和 XDocument
- 下一篇: asp.net ajax控件工具集 Au