温馨提示:本文翻译自stackoverflow.com,查看原文请点击:c# - How to enable count in OData and .NET Core 3.0 on ASP .NET Application?
c# count odata

c# - 如何在ASP .NET应用程序上的OData和.NET Core 3.0中启用计数?

发布于 2020-04-20 09:54:19

当我发出请求时: http:// localhost:5000 / api / v1 / users?$ count = true

它返回对象及其属性值,但不返回用户数:

在此处输入图片说明

这是我在控制器中的操作:

   /// <summary>
    /// Gets the list of all available users in the system
    /// </summary>
    /// <returns></returns>
    [HttpGet]
    [EnableQuery]
    public IEnumerable<UserDto> Get()
    {
        var users = dbContext.Users.ToList();

        return users.Select(u =>
        {
            var dto = mapper.Map<UserDto>(u);
            var claims = dbContext.UserClaims.Where(c => c.UserId == u.Id);
            dto.FirstName = claims.FirstOrDefault(c => c.ClaimType == JwtClaimTypes.GivenName)?.ClaimValue;
            dto.FamilyName = claims.FirstOrDefault(c => c.ClaimType == JwtClaimTypes.FamilyName)?.ClaimValue;
            return dto;
        }).ToList();
    }

这是我的启动配置:

services.AddOData();

app.UseMvc(router =>
        {
            router.EnableDependencyInjection();
            router.Select().Expand().Filter().OrderBy().MaxTop(100).Count().EnableContinueOnErrorHeader();
            router.MapODataServiceRoute("odata", "odata", GetEdmModel());
        });

    IEdmModel GetEdmModel()
    {
        var odataBuilder = new ODataConventionModelBuilder();
        odataBuilder.EntitySet<IntentUser>("Users");
        return odataBuilder.GetEdmModel();
    }

查看更多

提问者
grozdeto
被浏览
13
Ralf Gellrich 2020-02-07 19:49

自从我更新到OData 7.3.0(和.Net Core 3.1)以来,我遇到了同样的问题。

如果在controler类上使用[Route(...)]和[ApiController],也许就是问题所在。消失路线属性和ApiController属性:https ://stackoverflow.com/a/58849806/12858107