0X1 什么是依赖注入

  依赖注入(Dependency Injection),是这样一个过程:某客户类只依赖于服务类的一个接口,而不依赖于具体服务类,所以客户类只定义一个注入点。在程序运行过程中,客户类不直接实例化具体服务类实例,而是客户类的运行上下文环境或专门组件负责实例化服务类,然后将其注入到客户类中,保证客户类的正常运行。

                                                      图1

  如图1所示,数据库操作类DataManager中依赖的IDataBase的接口,而不是以来IDataBase的具体实现类,这样的好处是可以让我们的程序具有扩展性:无论我们要使用SqlServer当我们的数据库操作类还是用Mysql,我们需要改动的地方都很少。

0X2 一个Demo理解Di

  我们创建一个控制台程序,并按照图1中所标识的关系创建四个类。

public class DataManager
{
private IDataBase _database;
public DataManager(IDataBase database)
{
this._database = database;
} public void Add()
{
_database.Add();
} public void Delete()
{
_database.Delete();
} public void Update()
{
_database.Update();
} public void Select()
{
_database.Select();
}
}

IDataBase接口

public interface IDataBase
{
string DbName { get; }
void Select();
void Update();
void Delete();
void Add();
}
public class SqlServer : IDataBase
{
public string DbName
{
get
{
return "SqlServer";
}
} public void Add()
{
Console.WriteLine("Add in " + DbName);
} public void Delete()
{
Console.WriteLine("Delete in " + DbName);
} public void Select()
{
Console.WriteLine("Select in " + DbName);
} public void Update()
{
Console.WriteLine("Update in " + DbName);
}
}

  

public string DbName
{
get
{
return "Mysql";
}
} public void Add()
{
Console.WriteLine("Add in " + DbName);
} public void Delete()
{
Console.WriteLine("Delete in " + DbName);
} public void Select()
{
Console.WriteLine("Select in " + DbName);
} public void Update()
{
Console.WriteLine("Update in " + DbName);
}

如果我们要用Sqlserver作为数据库实现类的话,传统写法我们要New Sqlserver,如下图:

项目早期使用的是Sqlserver数据库没问题,后来BOSS忽然要改成Mysql数据库,你心里面一想,没问题啊,无非就是把New后面的Sqlserver换成Mysql嘛,简单。于是你就开始改,越改越不对劲,已经你已经发现当前项目已经有好几十个地方用到New Sqlserver(),而剩余的数量往往还是未知的。这个时候你就在想,有没有方法可以让我只需要改一个地方其他地方不用动就可以呢?答案是肯定的,目前这种方法实现有很多种,最简单的无非就是工厂模式。但是,今天,我们不用工厂,我们将使用Ninject来实现这种功能。

0X3 Ninject的使用

  Ninject是一个IOC容器,用来解决程序中组件的耦合问题,它的目的在于做到最少配置。其他的的IOC工具过于依赖配置文件,需要使用assembly-qualified名称来进行定义,庸长且复杂常常因为打错字而破坏程序。这些是他的优点,也是为什么要选择它。

  

安装Ninject

  打开Nuget程序包管理控制台输入“Install-Package Ninject”即可安装Ninject。

  

Ninject使用步骤

  我们一般会在程序启动的入口来创建Ninject的对象负责类型的注册。

  static void Main(string[] args)
{
//实例化Ninject对象
IKernel Kerner = new StandardKernel();
}

  使用Ninject对象分两个步骤,第一步是把接口对象或者说被依赖的对象(IDataBase)绑定到Ninject中,然后在为其绑定对应的实例类型(如果要使用SqlServer则就绑定SqlServer)。

 //实例化Ninject对象
IKernel Kerner = new StandardKernel();
//绑定对象
Kerner.Bind<IDataBase>().To<SqlServer>();

  第二步则是通过Ninject的Get方法获取IDataBase的实现类

 var Db = Kerner.Get<IDataBase>(); //由于上面IDataBase绑定的是SqlServer类型,所以这里获取的类型是SqlServer

  上面的代码大家可能体会不到使用Ninject的好处,也没有体会到依赖注入的奥妙所在。依赖注入大致分为三类:接口注入,函数注入,属性注入。我们来通过一个例子来演示属性注入。

  我们增加一个IShowDBInfo的接口类,其有一个Show方法。然后添加一个Show类实现IShowDBInfo接口:

 public class Show1 : IShowDBInfo
{
public void Show()
{
Console.WriteLine(this.GetType().FullName);
}
}

我们给DataManager添加一个IShowDBInfo属性并增加一个Show()方法:

 public class DataManager
{
private IDataBase _database;
private IShowDBInfo _showDbInfo;
public DataManager(IDataBase database, IShowDBInfo ishowdbinfo)
{
this._database = database;
_showDbInfo = ishowdbinfo;
}
//省略Add,Updata,Delete,Select方法
public void Show()
{
_showDbInfo.Show();
}
}

  在应用程序启动的时候注册IShow类和注册DataManager类并启动程序:

 static void Main(string[] args)
{
//实例化Ninject对象
IKernel Kerner = new StandardKernel();
//绑定对象
Kerner.Bind<IDataBase>().To<SqlServer>();
Kerner.Bind<IShowDBInfo>().To<Show1>();
Kerner.Bind<DataManager>().ToSelf();
var dataManager=Kerner.Get<DataManager>();
dataManager.Show();
Console.Read();
}

  从上代码以及运行结果来看,我们只需要在向Ninject实例里面注册对象,然后在其他类中使用的时候我们只需要定义接口就可以了,并不需要实例化对象。这样做的话可以使我们和其他层进行松耦合。

ASP.NET MVC进阶之路:依赖注入(Di)和Ninject的更多相关文章

  1. MVC进阶之路:依赖注入(Di)和Ninject

    MVC进阶之路:依赖注入(Di)和Ninject 0X1 什么是依赖注入 依赖注入(Dependency Injection),是这样一个过程:某客户类只依赖于服务类的一个接口,而不依赖于具体服务类, ...

  2. 依赖注入(DI)和Ninject

    [ASP.NET MVC 小牛之路]04 - 依赖注入(DI)和Ninject 本文目录: 1.为什么需要依赖注入 2.什么是依赖注入 3.使用NuGet安装库 4.使用Ninject的一般步骤 5. ...

  3. 依赖注入(DI)和Ninject,Ninject

    我们所需要的是,在一个类内部,不通过创建对象的实例而能够获得某个实现了公开接口的对象的引用.这种“需要”,就称为DI(依赖注入,Dependency Injection),和所谓的IoC(控制反转,I ...

  4. 什么是IOC和什么是AOP,依赖注入(DI)和Ninject,Ninject

    我们所需要的是,在一个类内部,不通过创建对象的实例而能够获得某个实现了公开接口的对象的引用.这种“需要”,就称为DI(依赖注入,Dependency Injection),和所谓的IoC(控制反转,I ...

  5. [ASP.NET MVC 小牛之路]04 - 依赖注入(DI)和Ninject

    本人博客已转移至:http://www.exblr.com/liam  为什么需要依赖注入 在[ASP.NET MVC 小牛之路]系列的理解MVC模式文章中,我们提到MVC的一个重要特征是关注点分离( ...

  6. ASP.NET MVC进阶之路:深入理解依赖注入(DI)和控制反转(IOC)

    0X1 什么是依赖注入 依赖注入(Dependency Injection),是这样一个过程:某客户类只依赖于服务类的一个接口,而不依赖于具体服务类,所以客户类只定义一个注入点.在程序运行过程中,客户 ...

  7. Asp.Net Mvc使用Autofac实现依赖注入

    在asp.net mvc控制器中使用Autofac来解析依赖 如下Controller中使用构造函数依赖注入接口IPeople : public class AutoFacController : C ...

  8. ASP.NET中IOC容器Autofac(依赖注入DI 控制反转IOC)

    IOC的一个重点是在程序运行中,动态的向某个对象提供它所需要的其他对象.这一点是通过DI来实现的.Autofac则是比较流行的一款IOC容器. IoC和DI有什么关系呢?其实它们是同一个概念的不同角度 ...

  9. ASP.NET MVC进阶之路:深入理解Controller激活机制并使用Ioc容器创建对象

    本文标题说是"深入理解Controller"其实有点“标题党”的味道了.本篇只会探讨"Controller"的激活机制,也就是如何创建Controller的并调 ...

随机推荐

  1. asp.net MVC Razor 语法(2)

    变量是用于存储数据的命名实体. 变量 变量用于存储数据. 变量名必须以字母字符开头,不能包含空格和保留字符. 变量可以是某个具体的类型,指示其所存储的数据类型.字符串变量存储字符串值 ("W ...

  2. sql server dateadd()

    定义和用法 DATEADD() 函数在日期中添加或减去指定的时间间隔. 语法 DATEADD(datepart,number,date) date 参数是合法的日期表达式.number 是您希望添加的 ...

  3. json中头疼的null

    在服务器返回 json 数据的时候,时常会出现如下数据 "somevalue":null 这个时候,json 解析的时候,就会吧这个 null 解析成 NSNull 的对象,我们向 ...

  4. Java多线程yield

    前言: 前几天复习了一下多线程,发现有许多网上讲的都很抽象,所以,自己把网上的一些案例总结了一下! 一. Thread.yield( )方法: 使当前线程从执行状态(运行状态)变为可执行态(就绪状态) ...

  5. [置顶] 修改Android开机画面之rle制作

    第一个动画: Bootloader开机使用的图片是linux.bmp,长高分别是120*120,色度是32,所以可以拿相同格式图片替换,进行编译烧写即可. 第二个图片:内核logo 这个修改方式,我在 ...

  6. 5.7.2.1 Math对象

    ECMAScript还为保存数学公司公式和信息提供了一个公共位置,即Math对象.与我们在JavaScript直接编写的计算功能相比,Math对象提供的计算功能执行起来要快得多.Math对象中还提供了 ...

  7. 50句高级SQL语句

    一个题目涉及到的50个Sql语句 --(下面表的结构以给出,自己在数据库中建立表.并且添加相应的数据,数据要全面些. 其中Student表中,SId为学生的ID) ------------------ ...

  8. MySQL学习系列一---命令行连接mysql和执行sql文件

    1.命令行连接mysql #mysql -h(主机) -u(用户名) -p (数据库名) mysql -hlocalhost -uroot -p testdb Enter password: **** ...

  9. Web存储(Web Storage)介绍

    Web存储即在客户端存储数据. 在没有Web Storage之前,是通过cookie来在客户端存储数据的.但是由于 浏览器能存cookie数比较少.如IE8,Firefox,opera每个域可以保存的 ...

  10. Eclipse中搭建Python开发环境

    转载:http://www.cnblogs.com/realh/archive/2010/10/04/1841907.html Eclipse+PyDev环境搭建 1.准备工作 JDK6 Java 开 ...