上一篇文章简要说明了MVC所代表的含义并提供了详细的项目及其控制器、视图等内容的创建步骤,最终完成了一个简单ASP.NET MVC程序。
  注:MVC与ASP.NET MVC不相等,MVC是一种开发模式,而ASP.NET MVC是MVC这种模式的其中一种实现方式,本文中提到的MVC如果没有特指,那么均表示ASP.NET MVC。
  本文将从ASP.NET的M-V-C到底代表什么?如何编写对应的代码?来讨论如何使用ASP.NET MVC开发应用程序。
  ○ ASP.NET MVC与分层
  ○ ASP.NET MVC中的M代表什么
  ○ ASP.NET MVC的V和C是如何交互的
  ○ ASP.NET MVC中的C应该如何处理业务逻辑
  ○ 如何使用ASP.NET MVC

ASP.NET MVC与分层

  什么是分层?

  在了解分层之前,先了解一下层次的概念,层次是指系统在结构或功能方面的等级秩序。具有多样性,可按物质的质量、能量、运动状态、空间尺度、时间顺序、组织化程度等多种标准划分。不同层次具有不同的性质和特征,既有共同的规律,又各有特殊规律。(来自百度百科)

  所以分层实际上是根据一定的标准和规律,将一个整体划分为多个层次,保证每一个层次中的内容都有共同的性质和特征,便于针对每一个层次进行维护管理。

  代码分层:

  代码分层就是将代码根据其功能特性将代码分而治之,代码分层一般分为三层(所以也被称为三层架构),分别是UI层、业务逻辑层和数据层,分层架构主要是把整个系统的数据存储、业务逻辑、UI实现进行关注点分离:
  ○数据层:关注数据是如何存储的不需要业务逻辑来处理,只需要调用相应接口就可以完成数据的获取、存储等功能。
  ○业务层:把业务区分出来可以更好的专注于业务逻辑的实现,对于一些业务逻辑较为复杂的系统可以使用领域驱动(DDD)的方法去实现。另外业务逻辑可以被重用,一个常见的例子就是MVC以及Web API,MVC用于Web端应用开发,Web API还可以用于为其它客户端或者是提供第三方应用使用,所以业务逻辑的实现不能在UI层,否则就回出现MVC的Controller中存在一份代码,而Web API的Controller中也存在相同的一份代码,以致于代码难以维护。
  ○UI层:需要做的就只有用户界面的设计,设计师只需要去关心如何将需要表达的内容完美的表达给用户并提高用户体验即可。 

  另外分层架构的“层”其实应该是根据业务特性、系统复杂度等因素来拆分的,分层可以让适合的人做适合的事情,并且设计模式中的“依赖倒置”原则定义模块直接要依赖抽象而不是实现,只要定义出抽象(接口)那么多个团队即可同时对不同的“层”进行开发。

  注:以上的分层架构特指服务端分层架构,像移动应用甚至一些单页应用也会特意的进行分层以享受分层带来的代码管理的便利。

  ASP.NET MVC是什么?

  在上一篇文章中介绍了ASP.NET MVC以及MVC分别代表的意义。从意义上看起来MVC的概念和三层架构的概念很相似,它们分别都对应了UI、业务逻辑和数据。但是它们有着很大的区别,MVC的View、Controller、Model的作用是处理UI显示、操作和数据交换。换句话说ASP.NET MVC在三层架构中仅仅是UI层的一种实现。

ASP.NET MVC中的M代表什么  

  M代表数据模型,但是应用程序中是存在多种数据模型的,比如与数据库一一对应的数据模型、用于显示的数据模型,ASP.NET MVC中很容易混用这两种模型,举个例子,用户信息除了用户特征还会包含用于登陆系统的密码等信息。对用户信息修改时除了修改特征还会修改密码等,但是在显示时就肯定不会把密码显示出来。还有一种情况就是一个列表页面,它不仅仅显示记录条目,还会显示分页信息,但是分页信息是不会存储到数据库中的,所以这两种模型是有明显区别的。  

  ASP.NET MVC在分层架构中被定位为UI的实现,那么这里的M应该被看作用于显示的数据模型。一些人也把它称为View Model,但是这个View Model与MVVM模式下的View Model有本质的区别,这里的View Model是用于显示的数据模型。

ASP.NET MVC的V和C是如何交互的

  根据之前的分析MVC的Model是用来展示的数据,所以理所应当的Controller应该生成一个Model交付给View来渲染。相反的,在通过Web页面提交一些数据时,这些数据来自View,那么View也应该提供一个Model交给Controller来执行相应的业务,它们的关系如下:

  

ASP.NET MVC中的C应该如何处理业务逻辑

  Controller用于处理来自客户端的请求,然后给出响应。而这个处理的过程就对应了实际的业务逻辑,而MVC又处于业务逻辑层之上,所以Controller唯一能做的就是直接调用业务逻辑,这里的调用应该是顺序的,没有任何逻辑判断的,所有的处理均交付给逻辑层。
  如何处理Controller和业务层的数据交换?视图模型还是实体模型(数据库模型)?
  首先视图模型不可用,因为MVC在业务层之上,如果使用视图模型,那么下层依赖上层是违反依赖原则的。而且视图模型可能包含分页等信息,也不是业务层需要的。
  其次可以用实体模型来交换,这个方案看上去可以,MVC以及业务都依赖一份实体模型。但是如果使用领域驱动来设计模型的时候怎么办?这时的“实体”包含了部分业务逻辑,而这部分的逻辑一般是不可以被UI层直接调用的。
  根据以上的分析发现两种都存在不符合的应用场景,所以引入了DTO(Data Transfer Object)数据传输对象这个概念,关于这个概念后续在分析,现在的博客系统先使用实体模型来处理数据交换。

如何使用ASP.NET MVC

  任何一个工具,不同的人可能会有不同的效果,对于软件开发来说除了完成功能性需求的开发,更重要的还有保证开发效率、软件质量、代码质量等非功能需求,以保证软件能够在适合的时间开发完成,代码可测试、可维护。但是不同的开发者使用工具习惯不一致,对于ASP.NET MVC来说,有的人可能习惯把Model当数据库模型和页面模型使用、把所有业务逻辑编写到Controller中、过多使用ViewBag等对象传输数据到View等。对于这些方法来说它仍然能够实现功能性需求,而且对于个人来说使用习惯的方法效率最高,但是对于一个团队来说这往往会造成很大的麻烦,每个人保持自己的风格,最后整个项目代码被改的面目全非,代码没有可读性、无法维护、无法测试等等。
  所以在使用工具前必须统一规范。没有规矩不成方圆。ASP.NET MVC 在某些角度上对于MVC来说也是一种规范。
  规范有好有坏,但无论好坏,只要存在规范,那么在修改规范时也会更容易,本系列文章会根据“博客系统”的进度来设定不同的规范,对于ASP.NET MVC的使用来说,应该有以下几点:
  ○ Controller只能顺序调用业务逻辑,不存在任何判断语句。
  ○ View在一般情况下只是用Controller传过来的Model对象,避免ViewBag等对象的使用。
  ○ Model只作为View和Controller之前的传输对象使用,与数据实体无关。

  小结:
  本章进一步的分析了MVC的概念,并在最后提出了规范,对于规范来说更多的指编码规范,比如命名规范、注释规范等等,这里的规范仅仅是对统一对ASP.NET MVC的使用方法,使得代码便于维护、测试,甚至后续使用代码生成器来生成代码也更加容易(关于代码规范等内容会在后续引入更多介绍)。

本文连接:http://www.cnblogs.com/selimsong/p/7646445.html

ASP.NET没有魔法——目录

ASP.NET没有魔法——ASP.NET MVC & 分层的更多相关文章

  1. ASP.NET没有魔法——ASP.NET MVC 与数据库大集合

    ASP.NET没有魔法——ASP.NET与数据库 ASP.NET没有魔法——ASP.NET MVC 与数据库之MySQL ASP.NET没有魔法——ASP.NET MVC 与数据库之ORM ASP.N ...

  2. ASP.NET没有魔法——ASP.NET MVC 路由的匹配与处理

    ASP.NET MVC的路由是MVC应用的一个核心也是MVC应用处理的入口,作为一个开发者,在正常情况下仅仅需要做的就是根据需求去定义实体.业务逻辑,然后在MVC的Controller中去调用.Vie ...

  3. ASP.NET没有魔法——ASP.NET MVC IoC

    之前的文章介绍了MVC如何通过ControllerFactory及ControllerActivator创建Controller,而Controller又是如何通过ControllerBase这个模板 ...

  4. ASP.NET没有魔法——ASP.NET MVC 过滤器(Filter)

    上一篇文章介绍了使用Authorize特性实现了ASP.NET MVC中针对Controller或者Action的授权功能,实际上这个特性是MVC功能的一部分,被称为过滤器(Filter),它是一种面 ...

  5. ASP.NET没有魔法——ASP.NET MVC使用Oauth2.0实现身份验证

    随着软件的不断发展,出现了更多的身份验证使用场景,除了典型的服务器与客户端之间的身份验证外还有,如服务与服务之间的(如微服务架构).服务器与多种客户端的(如PC.移动.Web等),甚至还有需要以服务的 ...

  6. ASP.NET没有魔法——ASP.NET MVC 模型绑定解析(下篇)

    上一篇<ASP.NET没有魔法——ASP.NET MVC 模型绑定解析(上篇)>文章介绍了ASP.NET MVC模型绑定的相关组件和概念,本章将介绍Controller在执行时是如何通过这 ...

  7. ASP.NET没有魔法——ASP.NET MVC Razor与View渲染

    对于Web应用来说,它的界面是由浏览器根据HTML代码及其引用的相关资源进行渲染后展示给用户的结果,换句话说Web应用的界面呈现工作是由浏览器完成的,Web应用的原理是通过Http协议从服务器上获取到 ...

  8. ASP.NET没有魔法——ASP.NET MVC Razor与View渲染 ASP.NET没有魔法——ASP.NET MVC界面美化及使用Bundle完成静态资源管理

    ASP.NET没有魔法——ASP.NET MVC Razor与View渲染   对于Web应用来说,它的界面是由浏览器根据HTML代码及其引用的相关资源进行渲染后展示给用户的结果,换句话说Web应用的 ...

  9. ASP.NET没有魔法——ASP.NET 身份验证与Identity

    前面的文章中为My Blog加入了文章的管理功能(ASP.NET没有魔法——ASP.NET MVC使用Area开发一个管理模块),但是管理功能应该只能由“作者”来访问,那么要如何控制用户的访问权限?也 ...

  10. ASP.NET没有魔法——ASP.NET Identity 的“多重”身份验证

    ASP.NET Identity除了提供基于Cookie的身份验证外,还提供了一些高级功能,如多次输入错误账户信息后会锁定用户禁止登录.集成第三方验证.账户的二次验证等,并且ASP.NET MVC的默 ...

随机推荐

  1. 融会贯通——最常用的“合成复用原则”技能点Get

    复用一个类的时候,多使用对象的组合/聚合的关联关系,而不是继承. 之前提到的"依赖倒转原则",是以里氏代换原则为基础的实现开闭原则目标的手段,这一条路线涉及到的是类的继承(包括单继 ...

  2. Java面试系列之HashMap大扫盲汇总

    PS:整理的稍微有点急,不足之处,望各路道友指正,List相关可以查看前一篇随笔! HashMap的工作原理是近年来常见的Java面试题,几乎每个Java程序员都知道HashMap,都知道哪里要用Ha ...

  3. python 斐波那契数列 fibonacci

    在python中生成fibonacci数列的函数 def fibonacci(): list = [] while 1: if(len(list) < 2): list.append(1) el ...

  4. 动态创建angular组件实现popup弹窗

    承接上文,本文将从一个基本的angular启动项目开始搭建一个具有基本功能.较通用.低耦合.可扩展的popup弹窗(脸红),主要分为以下几步: 基本项目结构搭建 弹窗服务 弹窗的引用对象 准备作为模板 ...

  5. RAID基础知识总结

    1.RAID RAID:Redundant Arrays of Inexpensive(Independent)Disks,即独立磁盘冗余阵列,简称磁盘阵列.简单地说就是把多个独立的硬盘组合起来,从而 ...

  6. CCNA+NP学习笔记—交换网络篇

    本章关于企业网络的最底层--交换层,难度较低,主要为以后三层的路由做铺垫.所有笔记的分类顺序为:序章→交换层→路由层→运营商,体现了从企业网到互联网的学习顺序. 注:思科设备命令行通常不分大小写!以后 ...

  7. 英语学习案例分析APP 201421123108 王坤彬

    第一部分.调研,测评 1.第一次使用经验. 我使用的时候苹果手机下载的必应软件.第一次使用感觉还好,但是知名度比较低,比不上喜马拉雅听书软件,这里我就做两者的对比.首先界面以及种类明显逼格更差点.必应 ...

  8. 201521123104 《JAVA程序设计》第二周学习总结

    1. 本周学习总结 认识了JAVA编程中一些类型与变量,了解了一些基本运算符的使用 变量在命名时,不可以使用数字或一些特殊字符作为开头 不可以声明局部变量后未指定任何值给它之前就使用变量 在程序中写下 ...

  9. 201521123105 第10周Java学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常与多线程相关内容. 2. 书面作业 本次PTA作业题集异常.多线程 1.finally 题目4-21.1 截图你的提交结果(出现 ...

  10. 201521123028 《Java程序设计》第12周学习总结

    1. 本周学习总结 流与文件 I/O流:Input/Output处理的简称,本质上就是一个数据序列.分为输入流Input Stream和输出流Output Stream. 最基本的可处理数据单位-by ...