这篇文章主要介绍“在ASP.NET Core中怎么使用HTTP标头传播”,在日常操作中,相信很多人在在ASP.NET Core中怎么使用HTTP标头传播问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”在ASP.NET Core中怎么使用HTTP标头传播”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
Demo
下面,我们创建 ServerA、ServiceB 两个 Web API 项目来演示这一功能。
首先,ServiceB 有一个 GET 方法,返回在请求中收到的所有标头,这使我们能够验证标头是否被传播:
public IHeaderDictionary Get(){return Request.Headers;}
执行 ServiceB 的 GET 请求,我们可以类似下图的响应:
现在,用 ServiceA 调用 ServiceB 并返回响应。
这将向我们显示哪些标头传播到 ServiceB:
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 标头被正确传播了:
到此,关于“在ASP.NET Core中怎么使用HTTP标头传播”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!