2

エラーモジュール(Application_Error)、HttpModuleMagic.MVC3、Ninject.MVC3、EF 4.1を使用してカスタムエラー処理(http://perspectivespace.com/100497697)を作成しようとしています。残念ながら、データベースにエラーを記録したい場合、「DbContextが破棄されたため、操作を完了できません」というエラーメッセージが表示されます。

誰か助けてくれませんか?

public class ErrorHandlerHttpModule : IHttpModule
{
    private const string ErrorControllerRouteName = "Error";
    private IErrorRepository errorRepo;
    private IUserRepository userRepo;

  //  private IUserRepository UserRepository;

    public ErrorHandlerHttpModule(IErrorRepository er, IUserRepository ur)
    {
        errorRepo = er;
        userRepo = ur;
    }

    public void Dispose()
    {
    }

    public void Init(HttpApplication context)
    {
        context.Error += Application_Error;
    }

    private void Application_Error(object sender, EventArgs e)
    {
        // Get the last error.

        var exception = HttpContext.Current.Server.GetLastError();
    ...

    error.User = userRepo.GetUserByName(name);

    ...

NinjectWebCommon.csの場合:

    private static void RegisterServices(IKernel kernel)
    {
        kernel.Bind<IErrorRepository>().To<ErrorRepository>().InRequestScope();
        kernel.Bind<IUserRepository>().To<UserRepository>().InRequestScope();

        kernel.Bind<IDatabaseFactory>().To<DatabaseFactory>().InRequestScope();

        kernel.Bind<IDisposable>().To<Disposable>().InRequestScope();
        kernel.Bind<IHttpModule>().To<ErrorHandlerHttpModule>();
    } 

...およびUserRepositoryクラス:

public class UserRepository : RepositoryBase<User>, IUserRepository
{
    public UserRepository(IDatabaseFactory databaseFactory)
    : base(databaseFactory)
    {
    } 

    public User GetUserByName(string name)
    {
        User us = null;
        try
        {
            us = dataContext.Users.Where(u => u.UserName.Equals(name)).FirstOrDefault() as User;
        }
        catch (Exception ex)
        {

        }
        return us;
    }
}

RepositoryBase:

public abstract class RepositoryBase<T> where T : class
{
    protected TestContext dataContext;
    private readonly IDbSet<T> dbset;
    protected RepositoryBase(IDatabaseFactory databaseFactory)
    {
        DatabaseFactory = databaseFactory;
        dbset = DataContext.Set<T>();
    }

    protected IDatabaseFactory DatabaseFactory
    {
        get;
        private set;
    }

    protected TestContext DataContext
    {
        get { return dataContext ?? (dataContext = DatabaseFactory.Get()); }
    }
    ...

およびDatabaseFactoryクラス:

public class DatabaseFactory : Disposable, IDatabaseFactory
{
    private TestContext dataContext;

    public TestContext Get()
    {
        return dataContext ?? (dataContext = new TestContext());
    }

    protected override void DisposeCore()
    {
        if (dataContext != null)
            dataContext.Dispose();
    }
}

この行はエラーを掘り下げます:

dataContext.Users.Where(u => u.UserName.Equals(name)).FirstOrDefault() as User;

私はこの記事をフォローしようとしています: http ://weblogs.asp.net/shijuvarghese/archive/2011/01/06/developing-web-apps-using-asp-net-mvc-3-razor-and-ef-code -first-part-1.aspx

ご回答ありがとうございます。

4

2 に答える 2

3
protected override void DisposeCore()
{
   if (dataContext != null)
   {
      dataContext.Dispose();
      dataContext = null;
   }
}
于 2012-08-15T14:00:14.947 に答える
-1

これは、LINQクエリが延期されるためです。つまり、「UserRepository」では実行されず、呼び出し元のコードでのみ実行されます。したがって、DBContextは、実行時にすでに破棄されています。変更することで、すぐに実行するように強制できます

us = dataContext.Users.Where(u => u.UserName.Equals(name)).FirstOrDefault() as User

us = dataContext.Users.Where(u => u.UserName.Equals(name)).ToList().FirstOrDefault() as User
于 2015-02-17T14:55:53.080 に答える