Asp.Net Mvc使用Autofac實現依賴注入

在asp.net mvc控制器中使用Autofac來解析依賴html

以下Controller中使用構造函數依賴注入接口IPeople web

api

    public class AutoFacController : Controller
    {
        public IPeople _people;

        public AutoFacController(IPeople people)
        {
            _people = people;
        }
        // GET: AutoFac
        public ActionResult Index()
        {
            ViewBag.test = _people.Getpeople();
            return View();
        }
    }

 如何使用AutoFac以下:mvc

一、在App_Start建立類文件AutofacConfig.cs框架

引用asp.net

using Autofac;
using Autofac.Integration.Mvc;

如下爲逐個註冊方法:ide

            //建立autofac管理註冊類的容器實例
            var builder = new ContainerBuilder();
            //下面就須要爲這個容器註冊它能夠管理的類型
            //builder的Register方法能夠經過多種方式註冊類型,以前在控制檯程序裏面也演示了好幾種方式了。
            builder.RegisterType<People>().As<IPeople>();

            //builder.RegisterType<DefaultController>().InstancePerDependency();
            //使用Autofac提供的RegisterControllers擴展方法來對程序集中全部的Controller一次性的完成註冊
            builder.RegisterControllers(Assembly.GetExecutingAssembly());
            //生成具體的實例
            var container = builder.Build();
            //下面就是使用MVC的擴展 更改了MVC中的注入方式.
            DependencyResolver.SetResolver(new AutofacDependencyResolver(container));

如下爲批量註冊方法:函數

    public class AutofacConfig
    {
        /// <summary>
        /// 負責調用autofac框架實現業務邏輯層和數據倉儲層程序集中的類型對象的建立
        /// 負責建立MVC控制器類的對象(調用控制器中的有參構造函數),接管DefaultControllerFactory的工做
        /// </summary>
        public static void Register()
        {
            //實例化一個autofac的建立容器
            var builder = new ContainerBuilder();
            //告訴Autofac框架,未來要建立的控制器類存放在哪一個程序集 (Wchl.CRM.WebUI)
            Assembly controllerAss = Assembly.Load("Wchl.WMBlog.WebUI");
            builder.RegisterControllers(controllerAss);

            //告訴autofac框架註冊數據倉儲層所在程序集中的全部類的對象實例
            Assembly respAss = Assembly.Load("Wchl.WMBlog.Repository");
            //建立respAss中的全部類的instance以此類的實現接口存儲
            builder.RegisterTypes(respAss.GetTypes()).AsImplementedInterfaces();

            //告訴autofac框架註冊業務邏輯層所在程序集中的全部類的對象實例
            Assembly serpAss = Assembly.Load("Wchl.WMBlog.Services");
            //建立serAss中的全部類的instance以此類的實現接口存儲
            builder.RegisterTypes(serpAss.GetTypes()).AsImplementedInterfaces();

            // builder.RegisterType<>().As<>();

            //建立一個Autofac的容器
            var container = builder.Build();
            //將MVC的控制器對象實例 交由autofac來建立
            DependencyResolver.SetResolver(new AutofacDependencyResolver(container));
        }
    }

 

二、在全局Global.asax類Application_Start()方法中調用AutofacConfig配置類方法ui

 

        protected void Application_Start(object sender, EventArgs e)
        {
            AutofacConfig.Register();
        }

 

三、Web Api配置Autofac方法spa

引用

using Autofac.Integration.WebApi;

參考資料:http://docs.autofac.org/en/latest/integration/webapi.html

  var builder = new ContainerBuilder();

  // Get your HttpConfiguration.
  var config = GlobalConfiguration.Configuration;

  // Register your Web API controllers.
  builder.RegisterApiControllers(Assembly.GetExecutingAssembly());

  // OPTIONAL: Register the Autofac filter provider.
  builder.RegisterWebApiFilterProvider(config);

  // Set the dependency resolver to be Autofac.
  var container = builder.Build();
  config.DependencyResolver = new AutofacWebApiDependencyResolver(container);
相關文章
相關標籤/搜索