据说.net 世界里,最强的依赖注入容器是Autofac 。不管是谁,Nopcommerce2.8 用了它,所以就简单研究一下喽。
用vs 2012 创建一个Asp.net mvc3 的样例项目。然后使用NuGet(Vs2012 自带的有,版本低的话,似乎要安装插件),下载安装autofac的dll,如图1,2.
图1 NuGet
图2 ,load autofac
autofac 要加载两个dll哦,一个是autofac 的core ,另外一个是和asp.net mvc3集成的dll
然后,我新建一个实体数据模型,链接我的数据库,加载Customer这个我已经建好的表,字段随意,数据随意。实体类Customer自动生成。加一个集合类,装customer,
public class LCust { public List<Customer> clist; }
接下来是一个ICusotmer接口和一个它的实现CustomerService:
public interface ICustomer { List<Customer>GetCustomers( ); } public class CustomerService : ICustomer { public List<Customer>GetCustomers() { return new SeendioEntities().T_Adv_Customer.ToList(); } }
好,准备工作就绪,开始依赖注入了。
在Gloabal.ascx文件中:
using Autofac; using Autofac.Builder; using Autofac.Integration.Mvc;
下面是编辑Application_Start()方法,对ICustomer进行依赖注入:
var builder = new ContainerBuilder(); builder.RegisterType<CustomerService>().As<ICustomer>();
在HomeController.cs中,修改构造函数:
private ICustomer _icustomer; public HomeController(ICustomer customerservice) { _icustomer = customerservice; }
修改action:
public ActionResult Index( ) { ViewBag.Message = "欢迎使用 ASP.NET MVC!"; List<Customer> clist = _icustomer.GetCustomers();//调用借口方法,获取所有的Customer LCust c = new LCust(); c.clist = clist; return View(c); //把Customer返回给视图 }
在index.cshtml 中显示Customer列表中每一个customer的email:
@model MvcApplication2.LCust @{ ViewBag.Title = "主页"; } <ul> @foreach (var item in Model.clist) { <li>@item.Email</li> } </ul>
运行,发现报了错:
解决这个问题的方法似乎不少,我翻了翻Nopcommerce 2.8的代码,发现了这么一个方法:RegisterControllers
于是在Application_Start()方法加上一句,对Controller进行依赖注入
builder.RegisterControllers(Assembly.GetExecutingAssembly());
问题解决,运行出结果。
Autofac 粗浅的用还简单,但是在Nopcommerce2.8里,我看到了对它进行封装的代码,好纠结。
autofac实现依赖注入的方法有哪些,注入对象的生命周期等等,继续分析,下次再会啊。