ASP.NET Web API - Entity Framework - 500 内部服务器错误。包含(param => param.field)

标签 asp.net sql linq entity-framework asp.net-web-api

我目前正在开发一个使用 Entity Framework 的数据库优先方法的 Web API 项目(我知道这还不是最稳定的平台),但我遇到了一些非常奇怪的事情。

当我的 APIController 中的 GET 方法尝试返回 DbSet 中的所有记录(涉及 LINQ Include() 方法,如下所示)时,它将返回 500 错误:

// GET api/Casinos
    public IEnumerable<casino> Getcasinos()
    {
            var casinos = db.casinos.Include(c => c.city).Include(c => c.state);
            return casinos.AsEnumerable();
        }

然而,这个方法工作正常,并从我的数据库中返回我的数据:

// GET api/States
    public IEnumerable<state> Getstates()
    {
        return db.states.AsEnumerable();
    }

因此,我在其他实例中证明,如果它返回没有 LINQ 查询的实体,它会很好地工作,但是当 DbContext 上使用 Include 方法时,它会失败。

当然,即使使用Fiddler、Chrome/Firefox开发工具,并添加GlobalConfiguration.Configuration.IncludeErrorDetailPolicy = IncludeErrorDetailPolicy.Always;,试图找到这个错误也是不可能的。

如果有人解决了这个问题,那么很高兴知道一个好的解决方案,这样我就可以开始返回我的数据了!谢谢!:)

附注我正在使用 SQL Server 2012

最佳答案

这是由于序列化 (Json/XML) 错误而发生的。问题是您直接尝试通过线路传输模型。作为示例,请参见以下内容:

public class Casino
{
    public int ID { get; set; }
    public string Name { get; set; }

    public virtual City City { get; set; }
}

public class State
{
    public int ID { get; set; }
    public string Name { get; set; }

    [XmlIgnore]
    [IgnoreDataMember]        
    public virtual ICollection<City> Cities { get; set; }
}

public class City
{
    public int ID { get; set; }
    public string Name { get; set; }

    public virtual  State State { get; set; }

    [XmlIgnore]
    [IgnoreDataMember]
    public virtual ICollection<Casino> Casinos { get; set; }
}

public class Context : DbContext
{
    public Context()
        : base("Casino")
    {

    }

    public DbSet<Casino> Casinos { get; set; }
    public DbSet<State> States { get; set; }
    public DbSet<City> Cities { get; set; }
}

请注意 XmlIgnoreIgnoreDataMember。您需要限制避免序列化,这样它就不会以循环方式发生。此外,上述模型仍然无法工作,因为它具有虚拟性。从任何地方删除虚拟,即 CityCitiesCasinosState,然后它会起作用,但效率很低.

总结:使用 DTO 并仅发送您真正想要发送的数据,而不是直接发送您的模型。

希望这有帮助!

关于ASP.NET Web API - Entity Framework - 500 内部服务器错误。包含(param => param.field),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11752495/

相关文章:

mysql - 我的 SQL 计数查询出了什么问题?

MYSQL 计数跨表事件的位置

c# - 如何替换字符串中找到的列表中的大量字符串值

c# - Linq 性能和延迟执行

c# - 代码优先迁移 - Entity Framework - 无法向表中添加列

asp.net - 如何在 ASP.NET 中设置默认页面?

asp.net - Visual Studio 2015 - 报表查看器 2015 可再发行版 - 让报表查看器 "12"正常工作

asp.net - 自动刷新浏览器缓存

mysql - 对mysql中子查询的结果有条件

c# - 如何将两个 IEnumerables 合并(或压缩)在一起?