将多态性与 DbContext 接口的正确方法是什么?



有没有办法直接在存储库中获取数据库上下文的实例,而不是在控制器中获取数据库上下文的实例?

我希望将其一直传递到存储库中的方法

步骤 1 - 控制器

    [Route("api/[controller]")]
    public class ModulesApiController : Controller
    {
        private readonly ApplicationDbContext _dbContext;
        private readonly ILogger _logger;
      
        public ModulesApiController(ILoggerFactory loggerFactory, **ApplicationDbContext dbContext**)
        {
            _logger = loggerFactory.CreateLogger<ModulesApiController>();
            _dbContext = dbContext;
        }

        [HttpGet]
        [Route("GetModule/{module}")]
        public async Task<JsonResult> GetModule(string module)
        {
            if (ModelState.IsValid)
            {
                try
                {
                    var ListModules = new List<ImoduleBL>();
                    ImoduleBL obj = new HomeModuleBL();
                    if (module == "home-index")
                    {
                        //obj = new HomeModuleBL();
                        //ListModules.Add(obj as ImoduleBL);
                        //List<Layout> ListObj = await GetModuleService.GetModule(ListModules);
                        //return Json(ListObj);
                    }
                    else if (module == "shop-index")
                    {
                        obj = new ShopModuleBL();
                        ImoduleBL Iobj = obj as ImoduleBL;
                        return  await GetModuleService.GetCateroy(Iobj, _dbContext);
                    }
                    else if (module == "top-bunner")
                    {
                    }
                }
                catch (Exception ex)
                {
                    _logger.LogError("Failed of : GetLayOutFor - Index Module", ex);
                    return null;
                }
            }
            return null;
        }
}

步骤 2 - 获取模块服务 - 服务

公共类 GetModuleService{_dbContext - 将其一直传递到存储库中的方法

public static async Task<JsonResult> GetCateroy(ImoduleBL ListModules, ApplicationDbContext _dbContext)
{
        return await ListModules.GetCateroy(_dbContext);
}

}

步骤 3 - 商店模块BL - BL

    public class ShopModuleBL : ImoduleBL
    {
        public async Task<JsonResult> GetCateroy(ApplicationDbContext _dbContext)
        {
            ImoduleBL ListModules;
            ShopModuleRepo obj = new ShopModuleRepo();
            ListModules = obj as ImoduleBL;
            return await GetModuleService.GetCateroy(ListModules, _dbContext);
        }
}

**步骤 4 - 商店模块存储库 - 存储库 **

public class ShopModuleRepo : ImoduleBL
{
    public async Task<JsonResult> GetCateroy(ApplicationDbContext _dbContext)
    {
        return new JsonResult(await _dbContext.Category1s.ToListAsync());
    }

}

**步骤 5 - 客户端 - CS **结果传递到角度应用程序.....

谢谢

你应该使用构造函数注入,而不是方法注入。如您所见,您正在通过每种方法传递数据库上下文实例,一直传递到存储库。如果使用构造函数注入,则不必执行此操作。

不幸的是,您到处都在更新实例。如果要使用构造函数注入,将设计更改为使用控制反转可能是有益的。很多关于这个的文章,看看它。

您的存储库将如下所示。

public class ShopModuleRepo : ImoduleBL
{
    public ShopModuleRepo(ApplicationDbContext dbContext) {
         if (dbContext == null)
             throw new ArgumentNullException(nameof(dbContext));
        _dbContext = dbContext;
    }
    private readonly ApplicationDbContext _dbContext;
    public async Task<JsonResult> GetCateroy()
    {
        return new JsonResult(await _dbContext.Category1s.ToListAsync());
    }
}

请注意方法 GetCateroy 中缺少参数。

现在,您可以从控制器中删除 db-context 字段,并删除所有其他类中的所有 db-context 参数。

相关内容

最新更新