AutoFac IoC DI 依赖注入 记录点点滴滴知识,为了更好的服务后来者! 一、为什么使用AutoFac? 之前介绍了Unity和Ninject两个IOC容器,但是发现园子里用AutoFac的貌似更为普遍,于是捯饬了两天,发现这个东东确实是个高大上的IOC容器~ Autofac是.NET领域最为流行的IOC框架之一,传说是速度最快的一个: 优点: 它是C#语言联系很紧密,也就是说C#里的很多编程方式都可以为Autofac使用,例如可以用Lambda表达式注册组件 较低的学习曲线,学习它非常的简单,只要你理解了IoC和DI的概念以及在何时需要使用它们 XML配置支持 自动装配 与Asp.Net MVC 3集成 微软的Orchad开源程序使用的就是Autofac,从该源码可以看出它的方便和强大 既然它都这么牛X了,我们用它就理所当然了,所以推荐其为IOC的终极解决方案! 二、AutoFac的使用 首先你必须获取AutoFac,这里你可以通过各种方式加载它,我这里还是通过VS中的NuGet来加载AutoFac,不论是哪种方式,最终的目的就是将 Autofac.dll,Autofac.Configuration.dll 这两个程序集引用到你的项目中。这样在你的项目中,如果想使用AutoFac,只需添加其命名空间引用即可~ 1、AutoFac入门 我们先定义一个数据访问的接口: public interface IDAL { void Insert(string commandText); } 然后用Sql和Oracle两种方式分别实现上述接口,不过这里只是演示而已,所以并没有真正去实现这两个类,你懂的~ SQL方式: 复制代码 复制代码 public class SqlDAL : IDAL { public void Insert(string commandText) { Console.WriteLine("使用sqlDAL添加相关信息"); } } 复制代码 复制代码 Oracle方式: 复制代码 复制代码 public class OracleDAL : IDAL { public void Insert(string commandText) { Console.WriteLine("使用OracleDAL添加相关信息"); } } 复制代码 复制代码 然后注入实现构造函数注入: 复制代码 复制代码 public class DBManager { IDAL _dal; public DBManager(IDAL dal) { _dal= dal; } public void Add(string commandText) { _dal.Insert(commandText); } } 复制代码 复制代码 最后要真正完成依赖注入就得AtuoFac登场了: 复制代码 复制代码 var builder = new ContainerBuilder(); builder.RegisterType(); builder.RegisterType().As(); using (var container = builder.Build()) { var manager = container.Resolve(); manager.Add("INSERT INTO Persons VALUES ('Man', '25', 'WangW', 'Shanghai')"); } 复制代码 复制代码 从以上栗子可以看出,其实AutoFac的使用跟Unity的使用有点像,关键的东东就是这个Container容器类 2、AutoFac常用方法说明 (1)builder.RegisterType().As():注册类型及其实例。例如下面就是注册接口IDAL的实例SqlDAL ContainerBuilder builder = new ContainerBuilder(); builder.RegisterType().As(); IContainer container = builder.Build(); SqlDAL sqlDAL = (SqlDAL)container.Resolve(); (2)IContainer.Resolve():解析某个接口的实例。例如上面的最后一行代码就是解析IDAL的实例SqlDAL (3)builder.RegisterType().Named(string name):为一个接口注册不同的实例。有时候难免会碰到多个类映射同一个接口,比如SqlDAL和OracleDAL都实现了IDAL接口,为了准确获取想要的类型,就必须在注册时起名字。 复制代码 builder.RegisterType().Named("sql"); builder.RegisterType().Named("oracle"); IContainer container = builder.Build(); SqlDAL sqlDAL = (SqlDAL)container.ResolveNamed("sql"); OracleDAL oracleDAL = (OracleDAL)container.ResolveNamed("oracle"); 复制代码 (4)IContainer.ResolveNamed(string name):解析某个接口的“命名实例”。例如上面的最后一行代码就是解析IDAL的命名实例OracleDAL (5)builder.RegisterType().Keyed(Enum enum):以枚举的方式为一个接口注册不同的实例。有时候我们会将某一个接口的不同实现用枚举来区分,而不是字符串,例如: public enum DBType{ Sql, Oracle} 复制代码 builder.RegisterType().Keyed(DBType.Sql); builder.RegisterType().Keyed(DBType.Oracle); IContainer container = builder.Build(); SqlDAL sqlDAL = (SqlDAL)container.ResolveKeyed(DBType.Sql); OracleDAL oracleDAL = (OracleDAL)container.ResolveKeyed(DBType.Oracle); 复制代码 (6)IContainer.ResolveKeyed(Enum enum):根据枚举值解析某个接口的特定实例。例如上面的最后一行代码就是解析IDAL的特定实例OracleDAL (7)builder.RegisterType().InstancePerDependency():用于控制对象的生命周期,每次加载实例时都是新建一个实例,默认就是这种方式 (8)builder.RegisterType().SingleInstance():用于控制对象的生命周期,每次加载实例时都是返回同一个实例 (9)IContainer.Resolve(NamedParameter namedParameter):在解析实例T时给其赋值 DBManager manager = container.Resolve(new NamedParameter("name", "SQL")); 复制代码 复制代码 public class DBManager { IDAL dal; public DBManager (string name,IDAL _dal) { Name = name; dal= _dal; } } 复制代码 复制代码 3、通过配置的方式使用AutoFac (1)先配置好配置文件 复制代码 复制代码 <?xml version="1.0"?>                               复制代码 复制代码 (2)读取配置实现依赖注入(注意引入Autofac.Configuration.dll) 复制代码 复制代码 static void Main(string[] args) { ContainerBuilder builder = new ContainerBuilder(); builder.RegisterType(); builder.RegisterModule(new ConfigurationSettingsReader("autofac")); using (IContainer container = builder.Build()) { DBManager manager = container.Resolve(); manager.Add("INSERT INTO Persons VALUES ('Man', '25', 'WangW', 'Shanghai')"); } 复制代码 复制代码 三、ASP.NET MVC与AtuoFac 终于到了ASP.NET MVC与AtuoFac双剑合璧的时候了,下面就看看AtuoFac在MVC中的应用,其实很简单,大概就几个步骤搞定: 1、首先在函数Application_Start() 注册自己的控制器类,一定要引入Autofac.Integration.Mvc.dll 复制代码 复制代码 using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Http; using System.Web.Mvc; using System.Web.Optimization; using System.Web.Routing; using Autofac; using AtuoFacOfMVC4.Models; using System.Reflection; using Autofac.Integration.Mvc; namespace AtuoFacOfMVC4 { public class MvcApplication : System.Web.HttpApplication { protected void Application_Start() { var builder = new ContainerBuilder(); SetupResolveRules(builder); builder.RegisterControllers(Assembly.GetExecutingAssembly()); var container = builder.Build(); DependencyResolver.SetResolver(new AutofacDependencyResolver(container)); AreaRegistration.RegisterAllAreas(); WebApiConfig.Register(GlobalConfiguration.Configuration); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); RouteConfig.RegisterRoutes(RouteTable.Routes); BundleConfig.RegisterBundles(BundleTable.Bundles); AuthConfig.RegisterAuth(); } private void SetupResolveRules(ContainerBuilder builder) { builder.RegisterType().As(); } } } 复制代码 复制代码 2、现在在你的MVC程序中注入依赖代码就ok了 (1)首先声明一个Student学生类 复制代码 复制代码 using System; using System.Collections.Generic; using System.Linq; using System.Web; namespace AtuoFacOfMVC4.Models { public class Student { public int Id { get; set; } public string Name { get; set; } public string Graduation { get; set; } public string School { get; set; } public string Major { get; set; } } } 复制代码 复制代码 (2)然后声明仓储接口及其实现 复制代码 复制代码 using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace AtuoFacOfMVC4.Models { public interface IStudentRepository { IEnumerable GetAll(); Student Get(int id); Student Add(Student item); bool Update(Student item); bool Delete(int id); } } 复制代码 复制代码 View Code (3)最后添加控制器StudentController,并注入依赖代码 复制代码 复制代码 using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; using AtuoFacOfMVC4.Models; namespace AtuoFacOfMVC4.Controllers { public class StudentController : Controller { readonly IStudentRepository repository; //构造器注入 public StudentController(IStudentRepository repository) { this.repository = repository; } public ActionResult Index() { var data = repository.GetAll(); return View(data); } } } 复制代码 复制代码 (4)最后为控制器StudentController的Index方法添加视图即可,这里不再详述,运行效果如下

转载于:https://www.cnblogs.com/zxtceq/p/8548810.html

AutoFac IoC DI 依赖注入相关推荐

  1. Spring IOC (DI) 依赖注入的四种方式

    依赖注入的四种方式: set 注入 赋值,默认使用的是set() 方法,依赖注入底层是通过反射实现的 <bean id="student" class="cust. ...

  2. .net程序开发IOC控制反转和DI依赖注入详解

    大部分应用程序都是这样编写的:编译时依赖关系顺着运行时执行的方向流动,从而生成一个直接依赖项关系图. 也就是说,如果类 A 调用类 B 的方法,类 B 调用 C 类的方法,则在编译时,类 A 将取决于 ...

  3. 控制反转 IOC 与依赖注入 DI

    引言 简单总结和巩固一下spring的核心原理--IOC和DI的概念,为什么IOC要叫控制反转?IOC和DI的关系是怎样的? 一.IOC 控制反转 初学者可能很好奇,为什么spring framewo ...

  4. 【Java从0到架构师】Spring - IoC 控制反转、DI 依赖注入

    IoC 控制反转.DI 依赖注入 Spring 简介 Spring 基本使用 - IoC 容器 依赖注入 (Dependency Injection) 基于 setter 的注入 - 自定义对象 be ...

  5. 什么是IOC(控制反转)、DI(依赖注入)举个形象的例子通俗易懂

    更多免费教学文章请关注这里 学习过Spring框架的人一定都会听过Spring的IoC(控制反转) .DI(依赖注入)这两个概念,对于初学Spring的人来说,总觉得IoC .DI这两个概念是模糊不清 ...

  6. [教程]控制反转(IoC)与依赖注入(DI)

    来源: http://zhangjunhd.blog.51cto.com/113473/126530/ 挺简单的,说的也很清楚 ※IoC/DI 依赖Java的反射机制 1.控制反转(Inversion ...

  7. 控制反转(IOC) 和依赖注入(DI) 的理解

    1.      IOC(控制反转) inverseof control是spring容器的内核,AOP.声明事务等功能在此基础上开花结果. 2.      通过实例理解IOC概念: 实例:<墨攻 ...

  8. Spring-初识Spring框架-IOC控制反转(DI依赖注入)

    ---恢复内容开始--- IOC :控制反转 (DI:依赖注入) 使用ioc模式开发 实体类必须有无参构造方法 1.搭建Spring环境 下载jar http://maven.springframew ...

  9. 什么是IOC(控制反转)、DI(依赖注入)

    原文地址(摘要了部分内容):https://blog.csdn.net/qq_22654611/article/details/52606960/ 学习过Spring框架的人一定都会听过Spring的 ...

最新文章

  1. Bioinformatics|基于知识图谱嵌入的药物靶标发现
  2. tableau应用实战案例(五十)-销售业绩的tableau可视化案例
  3. 读取jar包内部配置文件信息的解析
  4. javaweb jsp
  5. 三 .数据库(表操作)
  6. 【Silverlight】Bing Maps学习系列(九):自定义功能导航条(Custom NavigationBar)
  7. 中国高校改名(总结篇)(转载)
  8. 备考2个月如何一次性通过信息系统项目管理师
  9. 腾讯云发布容器安全白皮书
  10. 去除趋势杀软的退出密码
  11. 9860计算机测量程序,卡西欧9860测量放样程序-绘星
  12. index()函数和match()函数联合使用案例
  13. 理财十问:1.你知道自己的风险偏好吗?
  14. 鱼鹰软件签约新三板挂牌企业风盛股份
  15. hwd分别是长宽高_长宽高是什么意思
  16. 人群捕捞:你的隐私无处遁形
  17. 拨开迷雾 看见vivo穿越周期的秘密
  18. atof(),atoi(),itoa(),sprintf()等用法总结
  19. 【数据仓库学习】数据质量监控
  20. C#求100以内的质数

热门文章

  1. python属于什么专业类别-关于python:1D CNN用于分类
  2. 2018年计算机基础模拟试题,2018年大学计算机基础试题及答案
  3. ssh整合mysql不能自动生成表_ssh整合思想 Spring与Hibernate的整合 项目在服务器启动则自动创建数据库表...
  4. TensorFlow实现条件批归一化(Conditional Batch Normalization)
  5. sql 子查询 嵌套查询_SQL子查询– SQL中的嵌套查询
  6. sql limit 子句_SQL按子句排序
  7. 安装SQL Server Express和SQL Server Management Studio
  8. c ++创建二维数组_C ++中的二维数组
  9. 如何成为一个优秀的C++开发工程师?
  10. SpringCloud核心技术 | 初识SpringCloud微服务解决方案