AutoFac控制反转

2024-06-04 05:08
文章标签 控制 反转 autofac

本文主要是介绍AutoFac控制反转,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、AutoFac介绍

Autofac是.NET里IOC(Inversion of Control,控制反转)容器的一种,同类的框架还有Spring.NET,Unity,Castle等。可以通过NuGet方式添加到项目中使用。

官方网站:http://autofac.org/

Autofac相对于其它的IoC框架优点:

  1. 它是C#语言联系很紧密,也就是说C#里的很多编程方式都可以为Autofac使用,例如可以用Lambda表达式注册组件。
  2. 较低的学习曲线,学习它非常的简单,只要你理解了IoC和DI的概念以及在何时需要使用它们。
  3. XML配置支持。
  4. 自动装配。
  5. 与Asp.Net MVC集成。
  6. 微软的Orchad开源程序使用的就是Autofac,从该源码可以看出它的方便和强大。

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

控制反转(Inversion of Control,缩写为IoC),是面向对象编程中的一种设计原则,可以用来减低计算机代码之间的耦合度。Michael Mattson在1996年首次提出IoC的概念,IoC把创建和查找依赖对象的控制权交给了容器,由容器进行注入组合对象,所以对象与对象之间是松散耦合,而传统应用程序都是由我们在类内部主动创建依赖对象,从而导致类与类之间高耦合。

依赖注入(Dependency Injection,简称DI),早在2004年,Martin Fowler就提出了“哪些方面的控制被反转了?”这个问题。他总结出是依赖对象的获得被反转了,获得依赖对象的过程由自身管理变为了由IOC容器主动注入。于是,他给“控制反转”取了一个更合适的名字叫做“依赖注入”。

三、AutoFac应用

1.添加引用

Autofac.dll,autofac框架核心类库

Autofac.Integration.Mvc.dll,autofac框架对mvc的支持库

Autofac.Configuration.dll,autofac框架获取xml配置库

2.创建autofac容器,注入对象

    /// <summary>
    /// 依赖注入接口
    /// </summary>
    public interface IinjectContainer
    {
        void RegisterType<T>();

        T Resolve<T>();
    }

public class AutoFacContainer : IinjectContainer
    {
        private ContainerBuilder builder;
        private IContainer container;
        public AutoFacContainer()
        {
            //创建autofac容器
            builder = new ContainerBuilder();

            // 获取包含继承了IService接口类的程序集注入
            var assemblies = BuildManager.GetReferencedAssemblies().Cast<Assembly>().Where(assembly =>
                        assembly.GetTypes().FirstOrDefault(type => type.GetInterfaces().Contains(typeof(SQLTool.Service.IService))) != null).FirstOrDefault();
            builder.RegisterAssemblyTypes(assemblies).Where(t => t.GetInterface(typeof(SQLTool.Service.IService).Name) != null).AsImplementedInterfaces().InstancePerLifetimeScope();

            //注入xml文件<autofac>里配置的对象,可以写在web.config
            builder.RegisterModule(new ConfigurationSettingsReader("autofac"));

            //注入所有controller
            builder.RegisterControllers(Assembly.GetExecutingAssembly());

            //把容器装入到微软默认的依赖注入容器中
            container = builder.Build();
            DependencyResolver.SetResolver(new AutofacDependencyResolver(container));
        }

        public void RegisterType<T>()
        {
            builder.RegisterType<T>();
        }

        public T Resolve<T>()
        {
            return container.Resolve<T>();
        }
    }

3.IService及继承IService接口项目代码,web.config中autofac框架xml配置代码

    /// <summary>
    /// IService空接口,autofac批量注入时使用
    /// </summary>
    public interface IService: IDisposable
    {

    }

    /// <summary>
    /// 实现IService接口的具体接口
    /// </summary>
    public interface IEOP_OrderInfoService : SQLTool.Service.IService
    {
        List<EOP_OrderInfo> GetOrderInfo();
    }

    /// <summary>
    /// 实现接口的类
    /// </summary>
    public class EOP_OrderInfoService : ServiceBase, IEOP_OrderInfoService
    {
        /// <summary>
        /// 实现方法
        /// </summary>
        /// <returns></returns>
        public List<EOP_OrderInfo> GetOrderInfo()
        {
            //具体业务逻辑代码,项目中用ef框架查询的数据,测试的时候可以返回个字符串进行测试

            var list = Context.EOP_OrderInfo.ToList();
            return list;
        }
    }

xml配置文件代码

  <autofac>
    <components>
 <component type="HiMall_Test.IService.IEOP_OrderInfoService,EOP_OrderInfoService" service="HiMall_Test.SQLTool.Service.IService" />
    </components>
  </autofac>

4.创建对象容器

    public class ObjectContainer
    {
        private static ObjectContainer current;
        private static IinjectContainer container;

        public ObjectContainer(IinjectContainer inversion)
        {
            container = inversion;
        }

        public static ObjectContainer Current
        {
            get
            {
                if (current == null)
                {
                    RegisterAutoFac(container);
                }
                return current;
            }
        }
        /// <summary>
        /// 注册autofac
        /// </summary>
        /// <param name="autofac"></param>
        public static void RegisterAutoFac(IinjectContainer autofac)
        {
            container = autofac;
            current = new ObjectContainer(container);
        }

        public T Resolve<T>()
        {
            return container.Resolve<T>();
        }
    }

5.在Global.asax中调用autofac框架

protected void Application_Start()
        {
            ....

            //调用autofac框架
            ObjectContainer.RegisterAutoFac(new AutoFacContainer());
        }

5.Controller中调用

    public class HomeController : Controller
    {
        public IEOP_OrderInfoService _iEOP_OrderInfoService;

        public HomeController()
        {

        }

        public HomeController(IEOP_OrderInfoService iEOP_OrderInfoService)
        {
            this._iEOP_OrderInfoService = iEOP_OrderInfoService;
        }

        public ActionResult Index()
        {
            //方式1.构造器注入调用
            var list = _iEOP_OrderInfoService.GetOrderInfo();
            //方式2.使用容器Resolve调用
            var list1 = ObjectContainer.Current.Resolve<IEOP_OrderInfoService>().GetOrderInfo();
            if (list.Count > 0)
            {
                //log4net日志
                Core.Log.Debug("测试 : EOP_OrderInfo " + list.FirstOrDefault() == null ? "没数据" : list.FirstOrDefault().ClientID);
            }
            else
            {
                //log4net日志
                Core.Log.Debug("测试 : EOP_OrderInfo 啥都没有");
            }
            return View();
        }
    }

6.项目目录结构图

这篇关于AutoFac控制反转的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1029144

相关文章

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

控制反转 的种类

之前对控制反转的定义和解释都不是很清晰。最近翻书发现在《Pro Spring 5》(免费电子版在文章最后)有一段非常不错的解释。记录一下,有道翻译贴出来方便查看。如有请直接跳过中文,看后面的原文。 控制反转的类型 控制反转的类型您可能想知道为什么有两种类型的IoC,以及为什么这些类型被进一步划分为不同的实现。这个问题似乎没有明确的答案;当然,不同的类型提供了一定程度的灵活性,但

深入解析秒杀业务中的核心问题 —— 从并发控制到事务管理

深入解析秒杀业务中的核心问题 —— 从并发控制到事务管理 秒杀系统是应对高并发、高压力下的典型业务场景,涉及到并发控制、库存管理、事务管理等多个关键技术点。本文将深入剖析秒杀商品业务中常见的几个核心问题,包括 AOP 事务管理、同步锁机制、乐观锁、CAS 操作,以及用户限购策略。通过这些技术的结合,确保秒杀系统在高并发场景下的稳定性和一致性。 1. AOP 代理对象与事务管理 在秒杀商品

PostgreSQL中的多版本并发控制(MVCC)深入解析

引言 PostgreSQL作为一款强大的开源关系数据库管理系统,以其高性能、高可靠性和丰富的功能特性而广受欢迎。在并发控制方面,PostgreSQL采用了多版本并发控制(MVCC)机制,该机制为数据库提供了高效的数据访问和更新能力,同时保证了数据的一致性和隔离性。本文将深入解析PostgreSQL中的MVCC功能,探讨其工作原理、使用场景,并通过具体SQL示例来展示其在实际应用中的表现。 一、

vue2实践:el-table实现由用户自己控制行数的动态表格

需求 项目中需要提供一个动态表单,如图: 当我点击添加时,便添加一行;点击右边的删除时,便删除这一行。 至少要有一行数据,但是没有上限。 思路 这种每一行的数据固定,但是不定行数的,很容易想到使用el-table来实现,它可以循环读取:data所绑定的数组,来生成行数据,不同的是: 1、table里面的每一个cell,需要放置一个input来支持用户编辑。 2、最后一列放置两个b

【电机控制】数字滤波算法(持续更新)

文章目录 前言1. 数字低通滤波 前言 各种数字滤波原理,离散化公式及代码。 1. 数字低通滤波 滤波器公式 一阶低通滤波器的输出 y [ n ] y[n] y[n] 可以通过以下公式计算得到: y [ n ] = α x [ n ] + ( 1 − α ) y [ n − 1 ] y[n] = \alpha x[n] + (1 - \alpha) y[n-1]

OpenStack离线Train版安装系列—3控制节点-Keystone认证服务组件

本系列文章包含从OpenStack离线源制作到完成OpenStack安装的全部过程。 在本系列教程中使用的OpenStack的安装版本为第20个版本Train(简称T版本),2020年5月13日,OpenStack社区发布了第21个版本Ussuri(简称U版本)。 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版

OpenStack离线Train版安装系列—1控制节点-环境准备

本系列文章包含从OpenStack离线源制作到完成OpenStack安装的全部过程。 在本系列教程中使用的OpenStack的安装版本为第20个版本Train(简称T版本),2020年5月13日,OpenStack社区发布了第21个版本Ussuri(简称U版本)。 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版

OpenStack离线Train版安装系列—10.控制节点-Heat服务组件

本系列文章包含从OpenStack离线源制作到完成OpenStack安装的全部过程。 在本系列教程中使用的OpenStack的安装版本为第20个版本Train(简称T版本),2020年5月13日,OpenStack社区发布了第21个版本Ussuri(简称U版本)。 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版

OpenStack Victoria版——7.1控制节点-Neutron网络服务组件

7.1控制节点-Neutron网络服务组件 更多步骤:OpenStack Victoria版安装部署系列教程 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版 离线安装部署系列教程(全) OpenStack Train版 离线安装部署系列教程(全) 欢迎留言沟通,共同进步。 文章目录 一、创建n