gpt4 book ai didi

asp.net-mvc-3 - 使用 Ninject 的 InRequestScope() 时,DbContext 在第一次请求后释放

转载 作者:行者123 更新时间:2023-12-01 23:26:21 26 4
gpt4 key购买 nike

我对 EF 和 Ninject 都很陌生,所以如果这没有意义,请原谅我:)

我有一个带有 Ninject 和 Ninject.Web.Common 引用的 MVC3 应用程序。我正在尝试将 DbContext 注入(inject)我的存储库。我看到的是,在第一个请求中,一切都运行良好,但后续请求返回:

System.InvalidOperationException: The operation cannot be completed because the DbContext has been disposed.
at System.Data.Entity.Internal.LazyInternalContext.InitializeContext()
at System.Data.Entity.Internal.Linq.DbQueryProvider.Execute[TResult](Expression expression)
at System.Linq.Queryable.SingleOrDefault[TSource](IQueryable`1 source, Expression`1 predicate)

我的绑定(bind):

kernel.Bind<ISiteDataContext>().To<SiteDataContext>().InRequestScope();
kernel.Bind<IProductRepository>().To<ProductRepository>();
kernel.Bind<IProductService>().To<ProductService>();

我的服务类别:

public class ProductService : IProductService {
[Inject]
public IProductRepository repository {get; set;}

...
}

我的存储库类:

public class ProductRepository : IProductRepository {
[Inject]
public ISiteDataContext context {get; set;}

...
}

我的 SiteDataContext 类:

public class SiteDataContext  : DbContext, ISiteDataContext 
{
static SiteDataContext()
{
Database.SetInitializer<SiteDataContext >(null);
}

public DbSet<Product> Products{ get; set; }


protected override void Dispose(bool disposing)
{
base.Dispose(disposing);
}
}

我的 Controller :

public class ProductController {
[Inject]
public IProductService productService {get; set;}

...
}

如果我删除 .InRequestScope(),那么它可以正常工作 - 但这会导致 Entity Framework 出现问题,因为对象是在数据上下文的多个单独实例中修改的。

最佳答案

将您的存储库也设置为 InRequestScope。他们应该在每次请求后进行处理。

此外,对于 MVC,您还应该使用构造函数注入(inject)将存储库注入(inject)到 Controller 实例中。

关于asp.net-mvc-3 - 使用 Ninject 的 InRequestScope() 时,DbContext 在第一次请求后释放,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11149804/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com