为什么有这篇文章
最近在学ASP.NET MVC项目中使用Ioc,选用了Unity作为依赖注入的容器组件,在网上找了相关的文章简单实现了依赖注入,但想用文件配置的方式进行容器注入的注册,发现相关的文章实现的方式不适用,因为网上的文章大多是使用Unity 4.0.1的版本,而目前最新的Unity版本是5.8.6,使用配置进行容器注入的代码已然不同。
Ioc和Unity
IOC(Inversion of Control),即“控制反转”,是一种设计思想。有了IoC后,把创建和查找依赖对象的控制权交给了容器,由容器进行注入组合对象,所以对象与对象之间是松散耦合,这样也方便测试,利于功能复用,更重要的是使得程序的整个体系结构变得非常灵活。
Unity是微软Patterns & Practices 部门开发的一个轻量级的依赖注入容器。
代码准备
新建一个MVC项目,使用默认命名WebApplication1。在Model中新建下面3个类:
1
2
3
4
5
6
7
|
public class User
{
public int Id { get ; set ; }
public string UserName { get ; set ; }
public string Password { get ; set ; }
public string Email { get ; set ; }
}
|
1
2
3
4
|
public interface IUserDao
{
List<User> GetAllUsers();
}
|
1
2
3
4
5
6
7
8
9
|
public class EFUserDao : IUserDao
{
public List<User> GetAllUsers()
{
List<User> list = new List<User>();
//使用EF从数据库中读取数据...
return list;
}
}
|
HomeController中的Index()中编写代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
using WebApplication1.Models;
public class HomeController : Controller
{
public ActionResult Index()
{
IUserDao dao = new EFUserDao();
var list = dao.GetAllUsers();
//do something...
return View();
}
}
|
以上代码主要实现从数据库中获取用户列表数据到控制器中。
使用Unity
在项目引用上右击,管理Nuget程序包,搜索到Unity并安装。
HomeController中代码改动
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
using WebApplication1.Models;
using Unity;
public class HomeController : Controller
{
public ActionResult Index()
{
IUnityContainer container = new UnityContainer();
container.RegisterType<IUserDao, EFUserDao>();
var dao = container.Resolve<IUserDao>();
var list = dao.GetAllUsers();
//do something...
return View();
}
}
|
上面代码先声明一个Unity的容器,然后注册所需要的对象,最后调用。
按上面的方式,每次使用GetAllUsers()前都需要声明下,这里应该封装下。Unity在ASP.NET MVC中的使用已经将代码封装好了。
ASP.NET MVC使用Unity
使用Nuget安装Unity.MVC。
安装完成后会在~/App_Start/目录下自动生成UnityMvcActivator.cs和UnityConfig.cs文件。
打开UnityConfig文件,修改RegisterTypes()方法的代码
1
2
3
4
5
6
7
8
9
|
public static void RegisterTypes(IUnityContainer container)
{
// NOTE: To load from web.config uncomment the line below.
// Make sure to add a Unity.Configuration to the using statements.
// container.LoadConfiguration();
// TODO: Register your type's mappings here.
container.RegisterType<IUserDao, EFUserDao>();
}
|
注意引用
1
|
using WebApplication1.Models;
|
修改HomeController代码(使用构造函数注入)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
public class HomeController : Controller
{
IUserDao _iUserDao;
public HomeController(IUserDao iUserDao)
{
this ._iUserDao = iUserDao;
}
public ActionResult Index()
{
var list = _iUserDao.GetAllUsers();
//do something...
return View();
}
}
|
此方式是将依赖注入写在了代码中。然而并不灵活,每添加一组类,都要在UnityConfig中进行注册并编译一遍代码。我们更需要的是在配置文件中注册类型。
使用配置文件
修改UnityConfig文件中RegisterTypes()方法的代码:
1
2
3
4
5
6
7
8
9
|
public static void RegisterTypes(IUnityContainer container)
{
// NOTE: To load from web.config uncomment the line below.
// Make sure to add a Unity.Configuration to the using statements.
container.LoadConfiguration();
// TODO: Register your type's mappings here.
// container.RegisterType<IUserDao, EFUserDao>();
}
|
需要引用
1
|
using Microsoft.Practices.Unity.Configuration;
|
更改Web.Config的配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<?xml version= "1.0" encoding= "utf-8" ?>
<configuration>
<configSections>
<section name= "unity" type= "Microsoft.Practices.Unity.Configuration.UnityConfigurationSection, Unity.Configuration" />
</configSections>
<unity>
<containers>
<container>
<types>
<type type= "WebApplication1.Models.IUserDao, WebApplication1" mapTo= "WebApplication1.Models.EFUserDao, WebApplication1" />
</types>
</container>
</containers>
</unity>
......
</configuration>
|
运行站点,成功获取用户列表数据。
扩展
如果需求更改,要换用ADO.NET来操作数据库,只要建一个SQLUserDao的类,继承自IUserDao,然后将配置文件中的注册类型修改即可
1
|
<type type= "WebApplication1.Models.IUserDao, WebApplication1" mapTo= "WebApplication1.Models.SQLUserDao, WebApplication1" />
|
笔者使用的是VS2017进行操作。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:https://www.cnblogs.com/overlookr/archive/2018/07/10/9286613.html