4

在 Microsoft oData v4 代理客户端中,可以选择将身份验证令牌添加到每个请求中。可以通过以下方式实现:

var container = new Default.Container(new Uri(http://localhost:9000/));

//Registering the handle to the BuildingRequest event. 
container.BuildingRequest += (sender, e) => OnBuildingRequest(sender, e, accessToken);


//Every time a OData request is build it adds an Authorization Header with the acesstoken 
private static void OnBuildingRequest(object sender, BuildingRequestEventArgs e, TokenResponse token)
{
 e.Headers.Add("Authorization", "Bearer " + token.AccessToken);
}

我怎样才能使用简单的 odata 客户端做同样的事情?

4

2 回答 2

14

显然我应该解释为什么这是答案。

说明:这是为 Simple ODataClient 添加令牌的方式。

var settings = new ODataClientSettings(new Uri("http://localhost:9000/"));
settings.BeforeRequest += delegate(HttpRequestMessage message)
{
    message.Headers.Add("Authorization", "Bearer " + token.AccessToken);
};

var client = new ODataClient(settings);
于 2017-04-26T23:30:07.770 回答
9

不是使用委托方法来拦截并在每个 Http 调用上添加 Authorization 标头,更清晰/更清洁的解决方案是使用 HttpClient 实例实例化 ODataClient。

这也允许您控制 HttpClient 生命周期并重新使用它(无论如何您都应该正常使用它!)否则 ODataClient 将在每次调用时创建一个新的 HttpClient 实例,这只是效率低下并导致套接字层大量流失。通常不是问题,但可以处理大量代码,所以这只是一个好习惯。

下面的代码是使用 Azure AD OAuth2 令牌连接到 Dynamics 365 OData Web API 的 .Net 核心应用程序的摘录。

        httpClient.BaseAddress = new Uri(yourODataServiceRootURL);
        httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", yourBearerAccessToken);

        //Use the httpClient we setup with the Bearer token header
        var odataSettings = new ODataClientSettings(httpClient, new Uri("api/data/v9.1", UriKind.Relative));

        var odataClient = new ODataClient(odataSettings);
于 2019-10-14T05:08:30.027 回答