新聞中心
一、為什么使用AutoFac?

創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供棗強網(wǎng)站建設、棗強做網(wǎng)站、棗強網(wǎng)站設計、棗強網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、棗強企業(yè)網(wǎng)站模板建站服務,十年棗強做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。
之前介紹了Unity和Ninject兩個IOC容器,但是發(fā)現(xiàn)園子里用AutoFac的貌似更為普遍,于是捯飭了兩天,發(fā)現(xiàn)這個東東確實是個高大上的IOC容器~
Autofac是.NET領域最為流行的IOC框架之一,傳說是速度最快的一個:
優(yōu)點:
-
它是C#語言聯(lián)系很緊密,也就是說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入門
我們先定義一個數(shù)據(jù)訪問的接口:
- public interface IDAL
- {
- void Insert(string commandText);
- }
然后用Sql和Oracle兩種方式分別實現(xiàn)上述接口,不過這里只是演示而已,所以并沒有真正去實現(xiàn)這兩個類,你懂的~
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添加相關信息");
- }
- }
然后注入實現(xiàn)構造函數(shù)注入:
- 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
- ContainerBuilder builder = new ContainerBuilder();
- builder.RegisterType
().As (); - IContainer container = builder.Build();
- SqlDAL sqlDAL = (SqlDAL)container.Resolve
();
(2)IContainer.Resolve
(3)builder.RegisterType
- 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
(5)builder.RegisterType
- 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
(7)builder.RegisterType
(8)builder.RegisterType
(9)IContainer.Resolve
- 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)先配置好配置文件
(2)讀取配置實現(xiàn)依賴注入(注意引入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')");
- }
#p#
三、ASP.NET MVC與AtuoFac
終于到了ASP.NET MVC與AtuoFac雙劍合璧的時候了,下面就看看AtuoFac在MVC中的應用,其實很簡單,大概就幾個步驟搞定:
1、首先在函數(shù)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、現(xiàn)在在你的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)然后聲明倉儲接口及其實現(xiàn)
- 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);
- }
- }
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- namespace AtuoFacOfMVC4.Models
- {
- public class StudentRepository : IStudentRepository
- {
- private List
Articles = new List (); - public StudentRepository()
- {
- //添加演示數(shù)據(jù)
- Add(new Student { Id = 1, Name = "張三", Major = "軟件工程", Graduation = "2013年", School = "西安工業(yè)大學" });
- Add(new Student { Id = 2, Name = "李四", Major = "計算機科學與技術", Graduation = "2013年", School = "西安工業(yè)大學" });
- Add(new Student { Id = 3, Name = "王五", Major = "自動化", Graduation = "2013年", School = "西安工業(yè)大學" });
- }
- ///
- /// 獲取全部學生信息
- ///
- ///
- public IEnumerable
GetAll() - {
- return Articles;
- }
- ///
- /// 通過ID獲取學生信息
- ///
- ///
- ///
- public Student Get(int id)
- {
- return Articles.Find(p => p.Id == id);
- }
- ///
- /// 添加學生信息
- ///
- ///
- ///
- public Student Add(Student item)
- {
- if (item == null)
- {
- throw new ArgumentNullException("item");
- }
- Articles.Add(item);
- return item;
- }
- ///
- /// 更新學生信息
- ///
- ///
- ///
- public bool Update(Student item)
- {
- if (item == null)
- {
- throw new ArgumentNullException("item");
- }
- int index = Articles.FindIndex(p => p.Id == item.Id);
- if (index == -1)
- {
- return false;
- }
- Articles.RemoveAt(index);
- Articles.Add(item);
- return true;
- }
- ///
- /// 刪除學生信息
- ///
- ///
- ///
- public bool Delete(int id)
- {
- Articles.RemoveAll(p => p.Id == id);
- return true;
- }
- }
- }
(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方法添加視圖即可,這里不再詳述,運行效果如下
*將自己學習的點滴記錄并分享出來,既能使自己得到成長,偶爾也能幫助一下別人,何樂而不為呢?如果這篇文章對你還有點用的話,希望幫忙推薦一下~
網(wǎng)站題目:ASP.NETMVCIOC之AutoFac攻略
URL網(wǎng)址:http://www.5511xx.com/article/dhjhicd.html


咨詢
建站咨詢
