我正在进行web api集成测试。
我想将持有者令牌传递给Http请求的标头:
httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", "eJ43k5l435j34l5j43l5j34l5jl35j34l5j344l.4534535.534534sample...");
当这行代码完成后,我会查看httpClient.DefaultRequestHeaders.Authorization
属性并且它是NULL?
为什么会这样?
更新
这来自我的集成测试类的基类:
protected HttpClient Client { get { return server.HttpClient; } }
当我手动在测试类中新建一个http客户端时:
var client = new HttpClient();
client.DefaultRequestHeaders.Add("key","value");
它有效,但不适用于我的客户!?
更新2
好的我发现了这个:
var c = Client;
c.DefaultRequestHeaders.Add("bla", "bla");
IT工作,但为什么我必须在新变量中读取我的客户端?
答案 0 :(得分:0)
我已经读过(在一篇文章中我找不到,抱歉)HttpClient上的Auth标头(特别是在内存的TestServer主机中,显然无法处理经过身份验证的服务,因此对我来说似乎没什么用处?请参阅https://blog.kloud.com.au/2014/10/26/asp-net-web-api-integration-testing-with-one-line-of-code/“不幸的是,内存中的解决方案对我来说不起作用。看起来它无法处理身份验证。我使用UseJwtBearerAuthentication(JWT bearer token middleware),我的api调用导致401” )在webapi中只有GET - 我有同样的问题,试图对经过身份验证的端点进行集成测试 - 我得到了我的不记名令牌,将其添加到标题中,但在下一行代码中,它是NULL。
我发现的建议(以及我工作的解决方案)是将Bearer标头添加到HttpRequestMessage标头,而不是HttpClient标头,然后使用HttpClient.SendAsync而不是HttpClient.PostAsync(显然,无论出于何种原因,发布正文内容但不是标题)。
我已经浪费了太多时间试图解决这个问题,而且你发现的大多数教程都没有处理auth标题,所以我很惊讶更多的人不讨论这个问题(当然,假设我是不只是一个布偶)。但是,是的,尝试将您的auth标头添加到请求消息,而不是http客户端。