实体框架记录任何错误

时间:2017-01-12 09:38:10

标签: c# entity-framework logging exception-handling log4net

记录Entity Framework导致的任何出现错误的最佳做法是什么?

目前我正在使用log4net,但我认为这与日志框架无关。

关于示例API:

public class TestController : ApiController
{
    [HttpGet]
    public IEnumerable<Test> GetTests()
    {
        using(var context = new DatabaseContext())
        {
            return context.Tests.Where(w=>w.Enabled).ToList();
        }
    }
}

现在,我必须将我的方法体粘贴在try / catch中(我必须将所有控制器的所有方法体都粘贴在try / catch块中)

try
{
    using (var context = new DatabaseContext())
    {
        return context.Tests.Where(w=>w.Enabled).ToList();
    }
}
catch(Exception e)
{
    // TODO: handle also those ValidationErrors, thrown by Entity Framework
    // so here we get a lot more code
    _logger.Error(e);
}

但是我不想把我的API的任何方法体放在try / catch块中。

是否有可能在OnException类中添加DatabaseContext,我总是可以记录Entity Framework抛出的任何异常?

1 个答案:

答案 0 :(得分:2)

您可以查看以下内容:

Global Error Handling in ASP.NET Web API 2

Exception Filters

为了更进一步,如果您想获得有关底层命令的详细信息,您也可以实现Interceptor