MVC使用Spring.Net应用IOC(依赖倒置)学习笔记3_实用技巧

      到现在,我们已经基本搭建起了项目的框架,但是项目中还存在一个问题,就是尽管层与层之间使用了接口进行隔离,但实例化接口的时候,还是引入了接口实现类的依赖,如下面的代码:

private IUserService _userService;
private IUserService UserService
{
 get { return _userService ?? (_userService = new UserService()); }
 set { _userService = value; }
}

        面向接口编程,Controller应该只依赖于站点业务层的接口,而不能依赖于具体的实现,否则,就违背了在层之间设置接口的初衷了。

       另外,如果上层只依赖于下层的接口,在做单元测试的时候,就可以用Moq,Fakes等Mock工具来按实际需求来模拟接口的实现,就可以灵活的控制接口的返回值来对各种情况进行测试,如果依赖于具体的实现,项目的可测试性将大大减小,不利于进行自动化的单元测试。

要不依赖于具体的实现,就不能使用通常的 T t = new T() 的方式来获得一个类的实例了,需要通过IOC容器来对对象生命周期,依赖关系等进行统一的管理,这里,我们将使用Spring.Net应用IOC。 

Spring.Net在控制台程序中的使用 

我们将通过一个简单的控制台示例来展示Spring.Net的使用方法

创建测试用的类:

namespace SpringNetDemo
{
 public interface IClass
 {
  string Name { get; set; }
  Student Monitor { get; set; }
  string GetMsg();
 }
 public class Class : IClass
 {
  public string Name { get; set; }
  public Student Monitor { get; set; }

  public string GetMsg()
  {
   return "班级名称:" + Name + ",班长:" + Monitor.Name;
  }
 }

 public class Student
 {
  public string Name { get; set; }
 }
}

两个类,一个接口,Student类中有一个string类型的属性,为Name,Class类中除了string类型的Name属性外还有一个Student类型的Monitor属性,方法GetMsg可以返回当前Class对象的简介,包括班级名和班长名两个内容。Class类实现IClass接口。 

先做简单的测试:

IClass c6=new Class()
{
 Monitor = new Student()
 {
  Name = "李芙蓉"
 },
 Name = "六班"
};
Console.WriteLine(c6.GetMsg());
Console.ReadKey();

输出为:

接下来,我们换用Spring.Net容器来声明对象

1. 首先引用dll文件

   

需要核心库Spring.Core.dll和Spring.Net使用的日志记录组件Common.Logging.dll

2. 然后我们需要了解当前的程序集名称和命名空间

   

 3. 在项目中新建一个xml文件,命名为services.xml:

<?xml version="1.0" encoding="utf-8" ?>
<objects xmlns="http://www.springframework.net">
 <description>An example that demonstrates simple IoC features.</description>
 <object name="Class" type="SpringNetDemo.Class,SpringNetDemo">
 <property name="Name" value="尖子班"/>
 <property name="Monitor" ref="Student"/>
 </object>
 <object name="Student" type="SpringNetDemo.Student, SpringNetDemo">
 <property name="Name" value="陈二蛋"/>
 </object>
</objects>

      在xml中新建objects根节点,其中加入需要容器生成的object子节点,object子节点的type属性中需要指明类的完整名称(带有程序集)和当前命名空间,如果需要为当前类的属性赋默认值,则可以在object节点中增加property节点,配置其value属性来为类的属性赋初值,若类的属性仍然为其他类对象时,可以新建该类型的object节点,并给予其name属性,再在当前属性的property节点中将ref属性,指向新增object节点的name属性。

注意:要把xml文件设置为“如果较新则复制”或者“始终复制”,否则生成时将不会自动复制到程序目录

4.然后在应用程序配置文件中配置Spring.Net的信息:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
 <configSections>
 <sectionGroup name="spring">
  <section name="context" type="Spring.Context.Support.ContextHandler, Spring.Core"/>
  <section name="objects" type="Spring.Context.Support.DefaultSectionHandler, Spring.Core" />
 </sectionGroup>
 </configSections>
 <spring>
 <context>
  <resource uri="file://services.xml"/>
 </context>
 </spring>
</configuration>

运行程序,得到输出结果:

成功实现IOC

Spring.Net在ASP.NET MVC中的使用

方法和在控制台程序中大同小异

1. 同样,首先要导入dll文件

   

MVC项目中需要引用的dll文件稍多些,需要五个,除了值钱的两个外,还需要三个Web相关的dll。

2. 为了便于管理,我们在MVC项目更目录新建Config文件夹来保存配置文件,并在其中新建两个xml文件

controllers.xml:

<?xml version="1.0" encoding="utf-8" ?>
<objects xmlns="http://www.springframework.net">、
 <object type="PMS.WebApp.Controllers.UserController , PMS.WebApp" singleton="false" >
 <property name="UserService" ref="UserService" />
 </object>
</objects>

services.xml:

<?xml version="1.0" encoding="utf-8" ?>
<objects xmlns="http://www.springframework.net">
 <object name="UserService" type="PMS.BLL.UserService, PMS.BLL" singleton="false" >
 </object>
</objects>

同样是出于方便管理考虑,我们将控制器和业务类分两个文件来保存,文件中节点的规则与控制台示例中完全相同。

3.修改Web.config配置文件

在配置文件的configSections节点中增加如图的sectionGrup节点,configuration节点中增加Spring节点,并在spring节点中的context节点中使用resource节点设置配置文件的路径。

4. 修改Global文件

修改根目录的Global.asax文件,将MvcApplication类的父类由HttpApplication更改为SpringMvcApplication。

复制代码 代码如下:

public class MvcApplication : SpringMvcApplication//HttpApplication

5. 最后,将原来的控制器中代码修改,就成功地在MVC项目中使用Spring.Net实现了IOC

//private IUserService _userService;
//private IUserService UserService
//{
// get { return _userService ?? (_userService = new UserService()); }
// set { _userService = value; }
//}
private IUserService UserService { get; set; }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索mvc
, spring.net
, ioc
依赖倒置
,以便于您获取更多的相关知识。

时间: 2024-09-20 00:23:37

MVC使用Spring.Net应用IOC(依赖倒置)学习笔记3_实用技巧的相关文章

MVC使用极验验证制作登录验证码学习笔记7_实用技巧

       在之前的项目中,如果有需要使用验证码,基本都是自己用GDI+画图出来,简单好用,但是却也存在了一些小问题,首先若较少干扰线,则安全性不是很高,验证码容易被机器识别,若多画太多干扰线条,机器人识别率下降的同时,人眼的识别率也同步下降(震惊哭).更为重要的是,GDI+绘制的验证码一般来说也不会很美观,如果做一个炫酷的登陆界面却配了这样一个验证码,画风诡异,丑到极致.       再后来浏览网页的过程中,发现很多很多网站项目中都使用了一种叫极验验证的验证码,采用移动滑块的方式进行验证,方

MVC使用Log4Net进行错误日志记录学习笔记4_实用技巧

在Web应用运行过程中,我们难免会遇到程序运行异常,这个时候我们就应该将异常信息记录下来,以便开发人员和维护人员对异常原因进行还原,对异常原因进行修复.在ASP.NET平台中进行日志记录的组件也有很多,如Log4Net.CommonLogging等,我们这里选用Log4Net进行异常日志的记录. 1. 捕获异常 在ASP.NET MVC中提供了一个全局的异常处理过滤器:HandleErrorAttribute,可以通过该过滤器捕获异常信息. 我们在Models文件夹下新建类型Log4Except

ASP.NET MVC学习笔记_实用技巧

网上关于ASP.NET MVC的系列教程有好几个,所以就不从头开始介绍了,结尾处给大家推荐了几个链接,需要的话可以从头系统的看看. 1.ASP.NET MVC介绍及与ASP.NET WebForm的区别 刚开始为了搞清楚ASP.NET MVC到底值不值得用,翻来覆去想了一个多礼拜,看了好多资料和评论,最后决定还是值得一用.MVC不是一个简单的设计模式,更像一种架构模式,或者一种思想,刚开始一听MVC想到的就是模板引擎,NVelocity,StringTempleate等,但感觉如果只是为了用模板

MVC使用Controller代替Filter完成登录验证(Session校验)学习笔记5_实用技巧

之前的学习中,在对Session校验完成登录验证时,通常使用Filter来处理,方法类似与前文的错误日志过滤,即新建Filter类继承ActionFilterAttribute类,重写OnActionExecuting方法,之后直接在需要验证的Action前加上Filter标记即可. 1. 新建登陆校验类CheckLoginAttribute using System.Web.Mvc; namespace PMS.WebApp.Models { public class CheckLoginAt

MVC项目结构搭建及单个类的实现学习笔记1_实用技巧

新人刚开始学习ASP.NET MVC,若有不足之处希望能得到您的指点,不胜感激! 先来一张项目的层级结构图: Model:模型层,主要是各种类型.枚举以及ORM框架,框架完成数据库和实体类的映射.项目中选用了微软的开源ORM框架 EntityFramework 6.0 (以下简称EF),数据库则选择了微软的轻量级数据库SQL Server Compact 4.0本地数据库(简称Compact),Compact对EF支持比较完美,又属于文档型数据库,部署起来比较简洁. DAL:数据访问层,主要是对

MVC使用Memcache+Cookie解决分布式系统共享登录状态学习笔记6_实用技巧

      为了解决单机处理的瓶颈,增强软件的可用性,我们需要将软件部署在多台服务器上启用多个二级子域名以频道化的方式,根据业务功能将网站分布部署在独立的服务器上,或通过负载均衡技术(如:DNS轮询.Radware.F5.LVS等)让多个频道共享一组服务器.当我们将网站程序分部到多台服务器上后,由于Session受实现原理的局限,无法跨服务器同步更新Session,使得登录状态难以通过Session共享.       我们使用MemCache+Cookie方案来解决分布式系统共享登录状态的问题.

MVC使用T4模板生成其他类的具体实现学习笔记2_实用技巧

在前篇中我们已经将User类中的代码做了具体的实现,但仍然有多个实体类未实现,以后可能还会增加新的数据表,数据表结构也有可能发生变化,所以我们使用T4模板来完成类的生成,这样就算数据库表发生了改变,也会自动根据改变后的实体对类进行重新生成. 下面是数据访问层的T4模板文件 Dal.tt <#@ template language="C#" debug="false" hostspecific="true"#> <#@ inclu

[Unity 设计模式]IOC依赖倒置

1.前言 最近在看<游戏开发与设计模式>一书,看到控制反转设计模式,作者说:上层模块不应该依赖于下层模块,上层模块和下层模块都应该依赖于接口,这样能减少耦合.然后附带举了个例子,我觉得特别好,就是一台计算机是属于上层模块,里面硬盘属于下层模块,计算机依赖于硬盘,硬盘是计算机的基本组成部件之一.这里提到依赖一词,下面就详细谈谈依赖. 2.依赖 依赖就是一种联系关系,人对人的依赖那是一种羁绊关系.再拿上面的计算机举例,华硕是我们都耳熟能详的计算机厂商,西部数据和希捷都是硬盘厂商,如果说华硕依赖于某

Javascript依赖注入学习笔记

注意:不要将依赖注入和设计模式里的依赖倒置原则(Dependency Inversion Principle)混淆. 目标 设想我们有两个模块.第一个是负责Ajax请求服务(service),第二个是路由(router). var service = function() {      return { name: 'Service' }; } var router = function() {      return { name: 'Router' }; } //我们有另一个函数需要用到这两