使用HttpClient.GetAsync方法使用LINQ(Skip和Take)方法来提高性能?

时间:2018-04-28 12:32:54

标签: c# angular linq async-await

我使用以下代码检索JSON Feed的内容,如您所见,我使用了分页技术以及SkipTake这样的方法:

[HttpGet("[action]")]
public async Task<myPaginatedReturnedData> MyMethod(int page)
{
    int perPage = 10;
    int start = (page - 1) * perPage;

    using (HttpClient client = new HttpClient())
    {
        client.BaseAddress = new Uri("externalAPI");
        MediaTypeWithQualityHeaderValue contentType =
            new MediaTypeWithQualityHeaderValue("application/json");
        client.DefaultRequestHeaders.Accept.Add(contentType);
        HttpResponseMessage response = await client.GetAsync(client.BaseAddress);
        string content = await response.Content.ReadAsStringAsync();
        IEnumerable<myReturnedData> data = 
               JsonConvert.DeserializeObject<IEnumerable<myReturnedData>>(content);
        myPaginatedReturnedData datasent = new myPaginatedReturnedData
        {
            Count = data.Count(),
            myReturnedData = data.Skip(start).Take(perPage).ToList(),
        };
        return datasent;
    }
}

我的分页工作正常,但是我无法看到任何性能提升,我知道这是因为每当我请求新页面时,它会一次又一次地调用API 并且在检索完所有内容后,它会过滤它使用SkipTake方法,我正在寻找一种方法将SkipTake方法应用于我的HttpClient,以便它仅检索每个页面所需的记录。可能吗?如果是这样,怎么样?

1 个答案:

答案 0 :(得分:-1)

为了将Take / Skip应用于数据检索,服务器必须知道它们。您可以使用IQueryable LINQ提供程序(请参阅[1]以了解其复杂程度),或者更好的方法是将适当的值传递给client.GetAsync调用,例如

HttpResponseMessage response = await client.GetAsync(client.BaseAddress + $"?skip={start}&take={perPage}");

当然,您的服务器端代码必须正确解释这些skiptake参数;它不是自动的

您可能还想看看OData(参见[2]),但我从未在生产中使用它;我知道它存在。

[1] https://msdn.microsoft.com/en-us/library/bb546158.aspx

[2] https://docs.microsoft.com/en-us/aspnet/web-api/overview/odata-support-in-aspnet-web-api/odata-v3/calling-an-odata-service-from-a-net-client