ASP.NET + MVC5 入门完整教程三 (下) ---MVC 松耦合

article/2025/10/19 13:38:37

建立松耦合组件

MVC 模式最重要的特性之一视他支持关注分离,希望应用程序中的组件尽可能独立,只有很少的几个可控依赖项。在理想的情况下,每个组件都不了解其他组件,而只是通过抽象接口来处理应用程序的其他区域,这就称为“松耦合”,它使得的应用程序更易于测试和修改。

       举一个简单的例子:假设正在编写一个名称为“MyEmailSender”组件用来发送邮件,笔者会实现一个接口,他定义了发送邮件所需要的所有 Public 函数,该接口称为 “IEmailSender”(也就是说IEmailSender是一个接口,MyEmailSender是该接口的一个具体实现)。

      应用程序中需要发送电子邮件的任何其他组件,如“PasswordResetHelper”的口令重置辅助程序,那么只需要通过引用该接口中的方法便可以发送一份邮件,而在 PasswordResetHelper 和 MyEmailSender 之间没有直接的依赖关系。如下图表示:


通过引入 IEmailSender ,保证了 PasswordResetHelper 与 MyEmailSender 之间没有直接的依赖项,这样,编程人员可以完全使用另一个邮件发送程序来替换  MyEmailSender 甚至可以用一个模仿实现以进行测试,而无需对 PasswordResetHelper 做任何修改。关于模仿实现,敬请关注

依赖项注入

接口有助于解除组件耦合,这里人面临一个问题:C#未提供内置方法,以方便地创建实现接口对象,除非以 new 关键字创建一个具体组建的实例。如下代码所示:

  public class PasswordResethelper{public void ResetPassword(){IEmailSender mySender = new MyEmailSender();//调用接口方法 配置emailmySender.SendEmail;}}

       这种写法破坏了无需修改 PasswordResetHelper 就能替代 MyEmailSender 的目的,这就意味着此刻仅处于组建松耦合的半途,PasswordResetHelper 通过 IEmailSender 接口来配置并发送电子邮件,但是,为了创建实现该接口,必须创建 MyEmailSender 的一个实例,但实际上,事情变更加糟糕,因为 PasswordResetHelper 现在依赖于 MyEmailSender 类以及  IEmailSender 接口,如图所示:

       现在需要有种方法,他能获得实现某一接口的对象,而不用去直接创建该对象,这一问题的解决方案称为“依赖项注入(Eependency Injection, DI)”,也称为控制反转(Inversion of Control,IoC)。

DI 是一种实现组件解耦的设计模式。

打断和声明依赖项

DI 模式有两个部分,第一个部分是从组件(此例中PasswordResetHelper)中除去对具体类的依赖项。做法:创建一个类构造器,以所需接口的实现作为其参数:

        public class PasswordResethelper{private IEmailSender emailSender;public PasswordResetHelper(IEmailSender emailSenderParam){emailSender = emailSenderParam;}public void ResetPassword(){             //调用接口方法 配置emailmySender.SendEmail;}}

       现在可以将 PasswordResetHelper 类的构造器称为对 IEmailSender 接口声明了一个依赖项,就是说,除非接受一个实现 IEmailSender 接口对象,否则不能创建和使用它。在依赖项声明中,PasswordResetHelper 类不在有 MyEmailSender 的任何相关点,它仅仅依赖于 IEmailSender 接口,简单说来,就是 PasswordResetHelper 不在关心如何实现 IEmailSender 接口。

注射依赖项

       DI 模式的第二个部分是在创建 PasswordResetHelper 类实例时,注入由其申明的依赖项,故称为依赖项注入。这实际上意味着,对于打算使用的 IEmailSender 接口,需要决定是用哪一个类来实现,通过这个类创建一个对象,并将该对象作为参数传递给 PasswordResetHelper 构造器。

这种依赖项实在运行时才被注入到 PasswordResetHelper 中,所以只有在 PasswordResetHelper 类实例化期间才会创建IEmailSender 接口的实现类实例,并将其传递给 PasswordResetHelper 构造器。PasswordResetHelper 与依赖接口的实现类之间不存在编译时的依赖项。

使用依赖项注入容器

解决了依赖项问题,但如何对接口的具体实现进行实例化而无须在应用程序的某个其他地方创建依赖项呢?所以任然需要以下语句:

...
IEmailSender sender = new MyEmailSender();
herper =new PasswordResetHelper(sender);
...

      为了解决这个问题,引入“依赖项注入容器(Dependency Injection Container, 简称 DI 容器)”,也称为“IoC 容器”。这是一个组件,他在类(如 PasswordResetHelper)所声明的依赖项和用来解决这些依赖项的类(如 MyEmailSender)之间充当中间角色。


       我们不需要自己去编写DI 容器,如Ninject,使用NuGet 安装这个包。在 ASP.NET + MVC5 入门完整教程七 -—-- MVC基本工具(上) 中将会演示如何用Ninject.




http://chatgpt.dhexx.cn/article/IoNyiwJN.shtml

相关文章

MVC2 ,MVC3 ,MVC4,MVC5的区别

2010年發行ASP.NET MVC 2.0版,2011年發行ASP.NET MVC 3.0版,2012年發行ASP.NET MVC 4.0版 MVC3 需要.net framework 4.0 版本. 支持多视图引擎 在 ASP.NET MVC3 中,增加视图的对话框中允许你选择你希望的视图引擎,在新建项目…

MVC5+EF6 入门完整教程四

上篇文章主要讲了如何配置EF, 我们回顾下主要过程: 创建Data Model 创建Database Context 创建databaseInitializer配置entityFramework的context配置节。 对这个过程还有疑问的可以去上篇再看一下。 本次我们就主要讲解 (1) EF基本的CRUD (2) 涉及到的常用…

ASP.NET MVC 5 - 入门

注︰本教程的更新的版本是可用在这里使用视觉工作室 2015年。新的教程使用ASP.NET MVC 6 核心,其中在本教程中提供了许多改进。 本教程将教你基本的构建 ASP.NET MVC 5 web 应用程序使用Visual Studio 2013. 下载已完成项目. 本教程由斯科特 格思里(twitterscottgu…

05 MVC 模式

MVC 模式 一、概述 MVC 模式(Model–view–controller)是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller&…

MVC5 + EF6 入门完整教程二

从前端的UI开始 MVC分离的比较好,开发顺序没有特别要求,先开发哪一部分都可以,这次我们主要讲解前端UI的部分。 ASP.NET MVC抛弃了WebForm的一些特有的习惯,例如服务器端控件,ViewState这些东西,让Web回…

ASP.NET + MVC5 入门完整教程七 -—-- MVC基本工具(上)

这里主要介绍三类工具之一的 依赖项注入(DI)容器,其他两类 单元测试框架和模仿工具以后介绍。 1、准备示例项目 从创建一个简单的示例开始,名称为"EssentialTools" ,使用MVC空模板,如下所示: 创…

ASP.NET MVC 5 开发框架简介

1、新建项目 2、选择MVC模板 3、MVC框架简介 (1)App_Data: 该文件夹主要是包含应用程序的本地存储, 它通常以文件形式(如Microsoft SQL Server数据库文件, XML文件等)包含数据存储。 (2)App_Start: 该文件夹包含应用程序的配置逻…

asp.net mvc5 安装

原文地址 http://docs.nuget.org/docs/start-here/using-the-package-manager-console 工具-->NuGet程序包管理器-->程序包管理器控制台 然后 PM>Install-Package Microsoft.AspNet.Mvc -Version 5.0.0 Finding a Package From the Tools menu, select Library Pa…

MVC5 + EF6 入门完整教程

第0课 从0开始 ASP.NET MVC开发模式和传统的WebForm开发模式相比,增加了很多"约定"。 直接讲这些 "约定" 会让人困惑,而且东西太多容易忘记。 和微软官方教程不同,笔者尽量不用脚手架,从空白框架开始&…

ASP.NET + MVC5 入门完整教程二

从前端UI开始 MVC分离的比较好,开发顺序没有特别要求,先开发哪一部分都可以,这次我们主要讲解前端UI的部分。而谈到一个Web Application的UI,涉及到的无非就是html、css、 js这些东西。有兴趣的同学可以看看EsayUI。 任务 建立 注…

asp.net + MVC5 入门完整教程一

第1课 从0开始 从空白框架开始,一步一步添加功能,让大家能真正能用起来,理解每一个过程。 概述 本系列文章及文章中的例子主要基于微软官方文档 使用工具 : VS2014 sqlServer 2014 开始主要讲解MVC使用,后续同样也会提供MVC A…

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目

第一个MVC应用程序 1创建MVC项目 打开VS ,File--新建--项目,选择ASP Web项目,命名后确认。选择(Empty)空模板, 项目创建完成,会看到 解决方案管理器 窗口显示一些文件夹,如图&…

ASP.net MVC5 简介

ASP.net MVC5 简介 MVC是什么 MVC是一种设计模式。 也就是Model-View-Controller 模型-视图-控制器。 Model的功能 Model试数据模型,用来封装与程序相关的数据,以及对数据操作的处理方法。 有关“数据处理”的范围都可以属于Model,比如…

ASP.NET MVC5 网站开发实践 - 概述

前段时间一直在用MVC4写个网站开发的demo,由于刚开始学所有的代码都写在一个项目中,越写越混乱,到后来有些代码自己都理不清了。1月26日晚上在群里跟怒放 他们讨论这个问题,结论是即使只是一个小demo也应该分层来写。正好看到别人…

MVC5路由系统机制详细讲解

转自:http://www.lanhusoft.com/Article/213.html 请求一个ASP.NET mvc的网站和以前的web form是有区别的,ASP.NET MVC框架内部给我们提供了路由机制,当IIS接受到一个请求时,会先看是否请求了一个静态资源(.html,css,…

基于用户 的协同过滤算法

计算用户相似度和用户对未知物品的可能评分 基于用户的协同过滤算法主要包括两个步骤。 (1) 找到和目标用户兴趣相似的用户集合。 (2) 找到这个集合中的用户喜欢的,且目标用户没有听说过的物品推荐给目标用户。 例如现在有A、B、C、D四个用户,分别对a、…

JAVA开源协同过滤算法,推荐算法:协同过滤算法的介绍

一、什么是推荐算法 互联网的出现和普及给用户带来了大量的信息,满足了用户在信息时代对信息的需求,但随着网络的迅速发展而 带来的网上信息量的大幅增长,使得用户在面对大量信息时无法从中获得对自己真正有用的那部分信息,对信息…

协同过滤算法实验

本次呢,简单介绍一下协同过滤算法,并且给出简单的电影推荐实验作为举例说明。利用Spark MLlib中的协同过滤算法完成针对特定用户的电影推荐功能。这一部分需要实现实现输入用户id,输出为其推荐的电影。 一、协同过滤 所谓协同过滤&#xff0…

协同过滤算法及python实现

协同过滤算法及python实现 1.算法简介 协同过滤算法是一种较为著名和常用的推荐算法,它基于对用户历史行为数据的挖掘发现用户的喜好偏向,并预测用户可能喜好的产品进行推荐。也就是常见的“猜你喜欢”,和“购买了该商品的人也喜欢”等功能。…

协同过滤算法理论

1. 协同过滤算法 协同过滤(Collaborative Filtering)推荐算法是最经典、最常用的推荐算法。 所谓协同过滤,基本思想是根据用户之前的喜好以及其他兴趣相近的用户的选择来给用户推荐物品(基于对用户历史行为数据的挖掘发现用户的喜好偏向&…