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