我对 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/