.netCore2.0 依赖注入
依賴注入(ID)是一種實(shí)現(xiàn)對象及其合作者或者依賴想之間松散耦合的技術(shù)
對于傳統(tǒng)的方法來說,獲取類的方法通常用new如下
但是問題來了,如果我后期要修改MyServices類的時(shí)候,就需要在整個(gè)項(xiàng)目中來搜索修改
?
一:接口注入
為了實(shí)現(xiàn)解耦,我們需要建立IServices的接口,然后類實(shí)現(xiàn)接口,在控制器中進(jìn)行構(gòu)造函數(shù),初始化接口,然后使用接口來進(jìn)行操作,這樣就達(dá)到了解耦的目的,俗稱依賴注入
具體類代碼如下
1 namespace CoreWeb2.Services 2 { 3 public class MyServices:IServices 4 { 5 public string getName() 6 { 7 return "張三"; 8 } 9 } 10 public class OServices:IServices 11 { 12 public string getName() 13 { 14 return "李四"; 15 } 16 } 17 public interface IServices { 18 string getName(); 19 } 20 }控制器代碼如下:
1 namespace CoreWeb2.Controllers 2 { 3 public class DIController : Controller 4 { 5 /// <summary> 6 /// 通過構(gòu)造函數(shù)初始化接口 7 /// 在外界使用時(shí)候直接new出具體類,這樣就達(dá)到了程序解耦的目的,俗稱依賴注入 8 /// </summary> 9 public IServices _services; 10 public DIController(IServices services) 11 { 12 this._services = services; 13 } 14 public IActionResult Index() 15 { 16 //通過接口調(diào)用 17 _services.getName(); 18 return View(); 19 } 20 } 21 }但是問題又來了,因?yàn)榭刂破髂J(rèn)構(gòu)造函數(shù)是一個(gè)無參的,現(xiàn)在增加了參數(shù)傳遞,直接訪問會報(bào)錯(cuò)誤,因而就需要在Startup.cs中的ConfigureServices方法中進(jìn)行程序注入,將構(gòu)造函數(shù)的參數(shù)注入到容器中,當(dāng)程序訪問時(shí)會自動(dòng)在容器中找參數(shù),才可以使用
依賴注入有三種方式:
1、AddTransient
每個(gè)請求創(chuàng)建一個(gè)
2、AddScoped
一個(gè)域創(chuàng)建一個(gè)
3、AddSingleton
單例,整個(gè)應(yīng)用程序生命周期以內(nèi)只創(chuàng)建一個(gè)實(shí)例?
1 //每個(gè)請求創(chuàng)建一個(gè) 2 services.AddTransient<IServices, MyServices>(); 3 //一個(gè)域創(chuàng)建一個(gè) 4 services.AddScoped<IServices, MyServices>(); 5 //單例,整個(gè)應(yīng)用程序生命周期以內(nèi)只創(chuàng)建一個(gè)實(shí)例 6 services.AddSingleton<IServices, MyServices>();當(dāng)程序進(jìn)行依賴注入后,控制器中就可以訪問到當(dāng)前的實(shí)例對象了,
?二:泛型注入
泛型接口
/// <summary>/// 數(shù)據(jù)倉儲/// </summary>/// <typeparam name="TEntity"></typeparam>public interface IRepository<TEntity> where TEntity : class{DbContext DbContext { get; }DbSet<TEntity> Entities { get; }IQueryable<TEntity> Table { get; }TEntity GetById(object id);void Insert(TEntity engine, bool isSave = true);void Update(TEntity engine, bool isSave = true);void Delete(TEntity engine, bool isSave = true);}泛型接口實(shí)現(xiàn)
public class EfRepository<TEntity> : IRepository<TEntity> where TEntity:class{private GeneralDbContext _dbContext;public EfRepository(GeneralDbContext generalDbContext){_dbContext = generalDbContext;}public DbContext DbContext => _dbContext;public DbSet<TEntity> Entities => _dbContext.Set<TEntity>();public IQueryable<TEntity> Table => Entities;public void Delete(TEntity engine, bool isSave = true){Entities.Remove(engine);if (isSave){_dbContext.SaveChanges();}}public TEntity GetById(object id){return _dbContext.Set<TEntity>().Find(id);}public void Insert(TEntity engine, bool isSave = true){Entities.Add(engine);if (isSave){_dbContext.SaveChanges();}}public void Update(TEntity engine, bool isSave = true){Entities.Update(engine);if (isSave){_dbContext.SaveChanges();}}泛型注入方式
? //將泛型注入 services.AddScoped(typeof(IRepository<>),typeof(EfRepository<>));?
關(guān)聯(lián)類GeneralDbContext
public class GeneralDbContext : DbContext{public GeneralDbContext(DbContextOptions options) : base(options){ }public DbSet<Category> Categorys{ get; set; }}?
轉(zhuǎn)載于:https://www.cnblogs.com/happygx/p/8845835.html
總結(jié)
以上是生活随笔為你收集整理的.netCore2.0 依赖注入的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: iOS开发之登录注册系统
- 下一篇: django 分页功能