这篇文章主要介绍“在ASP.NET Core中怎么使用HTTP标头传播”,在日常操作中,相信很多人在在ASP.NET Core中怎么使用HTTP标头传播问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”在ASP.NET Core中怎么使用HTTP标头传播”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
下面,我们创建 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) { // 添加标头传播middleware app.UseHeaderPropagation(); ...... }
再次执行 ServerA 的 GET 请求,可以看到,Authorization 标头被正确传播了:
到此,关于“在ASP.NET Core中怎么使用HTTP标头传播”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。