一、为什么使用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
- 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)读取配置实现依赖注入(注意引入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、首先在函数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);
- }
- }
- 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()
- {
- //添加演示数据
- Add(new Student { Id = 1, Name = "张三", Major = "软件工程", Graduation = "2013年", School = "西安工业大学" });
- Add(new Student { Id = 2, Name = "李四", Major = "计算机科学与技术", Graduation = "2013年", School = "西安工业大学" });
- Add(new Student { Id = 3, Name = "王五", Major = "自动化", Graduation = "2013年", School = "西安工业大学" });
- }
- ///
- /// 获取全部学生信息
- ///
- ///
- 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方法添加视图即可,这里不再详述,运行效果如下
*将自己学习的点滴记录并分享出来,既能使自己得到成长,偶尔也能帮助一下别人,何乐而不为呢?如果这篇文章对你还有点用的话,希望帮忙推荐一下~
网页题目:ASP.NETMVCIOC之AutoFac攻略
文章网址:http://www.shufengxianlan.com/qtweb/news33/521983.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联