调用EntityFrameWork核心时AspNetCore 2.0崩溃(溢出异常)

时间:2017-09-07 13:06:31

标签: c# entity-framework asp.net-core asp.net-core-2.0 asp.net-core-mvc-2.0

我已经有这个问题已经有一段时间了,并且已经与微软谈过它,到目前为止还没有解决方案。 现在我在一个全新的项目中重现了错误。 我删除了所有不道德的代码,这段代码仍然给我错误:

System.StackOverflowException occurred
  HResult=0x800703E9
  Source=<Cannot evaluate the exception source>
  StackTrace:
<Cannot evaluate the exception stack trace>

我的项目包含一个包含以下内容的Startup.cs类:

public class Startup
{
    public Startup(IConfiguration configuration)
    {
        Configuration = configuration;
    }

    public IConfiguration Configuration { get; }

    public void ConfigureServices(IServiceCollection services)
    {
        services.AddDbContext<FrilivDB>(options => options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")).EnableSensitiveDataLogging());
        services.AddMvc();
    }

    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
    {
        app.UseMvc(routes =>
        {
            routes.MapRoute(name: "default", template: "{controller=Home}/{action=Index}/{id?}");
            routes.MapRoute("ViewProduct", "{brand}/{productTitle}", defaults: new { controller = "Products", action = "Details" });
        });
    }
}

My Productscontroller看起来像这样:

public class ProductsController : Controller
{
    private readonly FrilivDB _context;

    public ProductsController(FrilivDB context)
    {
        _context = context;
    }

    public async Task<IActionResult> Details(string brand, string productTitle)
    {
        var product = _context.Products.Select(p => p.Title);
        return View();
    }
}

当在调试器中通过此行时,会发生错误:

var product = _context.Products.Select(p => p.Title);

每次等待15到30秒后发生错误。 任何人有任何想法或经历过同样的事情吗?

这是我在输出窗口中看到的:

    AO.Shop>       Request starting HTTP/1.1 GET http://localhost:44317/tatonka/alaska  
AO.Shop> info: Microsoft.AspNetCore.Hosting.Internal.WebHost[1]
AO.Shop>       Request starting HTTP/1.1 GET http://localhost:44317/tatonka/alaska  
AO.Shop> info: Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker[1]
AO.Shop>       Executing action method AO.Shop.Controllers.ProductsController.Details (AO.Shop) with arguments (tatonka, alaska) - ModelState is Valid
AO.Shop> info: Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker[1]
AO.Shop>       Executing action method AO.Shop.Controllers.ProductsController.Details (AO.Shop) with arguments (tatonka, alaska) - ModelState is Valid
AO.Shop> 
AO.Shop> Process is terminating due to StackOverflowException.

2 个答案:

答案 0 :(得分:3)

经过对微软的大量沟通以及大量的调试和评论代码后,我发现了问题。

这是因为数据库设置不佳。 我的数据库中有4个表,它们将自己作为外键引用,从而给出了EF Core的Stackoverflow异常。

删除所有4并重建整个模型后,它工作正常。 感谢您的意见

答案 1 :(得分:-1)

添加一个或多个try-catch语句以获取有关正在生成的异常的更多信息。然后使用该信息更新代码以防止发生异常。

另外,请考虑查看Microsoft为ASP.NET 2.0提供的修补程序。此ASP.NET 2.0 hotfix rollup package page引用了一些可能适用于您的问题的问题。另一个选择是升级到ASP.NET 3.5+,但我认为你试图避免这种方法。

我希望这会有所帮助。