ASP.NET开发实战——(五)ASP.NET MVC & 分层
上一篇文章简要说明了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的使用方法,使得代码便于维护、测试,甚至后续使用代码生成器来生成代码也更加容易(关于代码规范等内容会在后续引入更多介绍)。
欢迎添加个人微信号:Like若所思。
欢迎关注我的公众号,不仅为你推荐最新的博文,还有更多惊喜和资源在等着你!一起学习共同进步!
ASP.NET开发实战——(五)ASP.NET MVC & 分层的更多相关文章
- [原创].NET 分布式架构开发实战五 Framework改进篇
原文:[原创].NET 分布式架构开发实战五 Framework改进篇 .NET 分布式架构开发实战五 Framework改进篇 前言:本来打算这篇文章来写DAL的重构的,现在计划有点改变.之前的文章 ...
- ASP.NET开发实战——(二)为什么使用ASP.NET
本文主要内容是通过分析<博客系统>需求,确定使用Web应用的形式来开发,然后介绍了HTML.HTTP的概念,并使用IIS搭建了一个静态的HTML“页面”,从而引出“动态”的ASP.NET. ...
- ASP.NET开发实战——(九)ASP.NET MVC 与数据库之ORM
之前的文章中介绍了如何在ASP.NET中通过ADO.NET操作SQL Server和My SQL数据库,数据库的操作是通过SQL语句的执行来完成的,在ASP.NET中还有一个简便的方式来使用数据库,那 ...
- ASP.NET开发实战——(八)ASP.NET MVC 与数据库之MySQL
之前介绍了My Blog如何使用ADO.NET来访问SQL Server获取数据.本章将介绍如何使用My SQL来完成数据管理. 在使用My SQL之前需确保开发环境中安装了My SQL数据库和Con ...
- ASP.NET开发实战——(六)ASP.NET MVC & 分层 代码篇
上一篇文章对如何规范使用ASP.NET进行了介绍,本章内容将根据上一篇得出的结论来修改博客应用的代码. 代码分层 综合考虑将博客应用代码分为以下几个层次: ○ 模型:代表应用程序中的数据模型,与数据库 ...
- ASP.NET开发实战——(四)ASP.NET MVC是如何运行的?它的生命周期是什么?
前面的文章我们使用ASP.NET MVC创建了个博客应用,那么它是如何工作的呢?我们都知道ASP.NET的程序需要部署到IIS上才能够通过浏览器来访问,那么IIS与ASP.NET MVC程序之间又是如 ...
- ASP.NET开发实战——(十)ASP.NET MVC 与数据库之MySQL&EF
之前介绍EF时介绍了provider这个配置项,而且也介绍了在ASP.NET访问MySQL数据仍然是通过ADO.NET,不同的地方仅仅是更换了MySQL的数据提供器,那么在EF中是否也只需更换“提供器 ...
- ASP.NET开发实战——(十二)ASP.NET MVC 与数据库之Entity Framework Migrations
在开发数据库应用程序的时候,经常会遇到某些表需要添加字段或者修改类型.新增表等需求,而对于EF Code First来说关注的只有实体类,当需求变更时只需要添加新的实体类或者在实体类中添加.删除.修改 ...
- ASP.NET开发实战——(十一)ASP.NET MVC 与数据库之EntityFramework配置与连接字符串
前几篇文章中介绍了如何使用Entity Framework来操作数据库,但是对EF的配置.连接字符串的指定仍然存在一些疑问,EF可以通过两种方式来实现配置,分别是代码方式和配置文件. 本章将通过以下几 ...
随机推荐
- iOS Workflow 分享 - Scan QR Code
很多时候我们无意识地用微信扫描一个 QR Code,然后无论打开的是什么我们用就是了.我经常会好奇到底 QR Code 编码的是什么信息,到底是一个 ID 呢,还是一个 URL(可能是 deeplin ...
- Python连载36-线程数量限制、Timer、可重入锁
一.允许一个资源最多由几个线程同时进行 命令行:threading.Semaphore(个数) 代表现在最多有几个线程可以进行操作 import threading import time #参数定义 ...
- CentOS安装etcd和flannel实现Docker跨物理机通信
1.安装etcd yum install etcd systemctl stop etcd systemctl start etcd systemctl status etcd systemctl e ...
- virtualbox 配置记录
virtualbox 网络模式 Host-only Internal Bridged NAT 之间的区别 host-only模式,host与vm一起在内部网络 Internal模式,仅vm在内部网络 ...
- 练手WPF(一)——模拟时钟与数字时钟的制作(下)
继续数字时钟.上一篇写好了数字笔划专用的DigitLine类.现在是时候使用它了.下面对一些主要代码进行说明. 打开MainWindow.xaml.cs文件: (1)添加字段变量 // 数字时钟字段定 ...
- 2019大厂Java岗面试题全曝光,刷完这1020道,金三银四大厂等你
2019大厂Java岗面试题全曝光,刷完这1020道,金三银四大厂等你 前言: 本文收集整理了各大厂常见面试题N道,你想要的这里都有 内容涵盖:Java.MyBatis.ZooKeeper.Dubbo ...
- vue学习指南:第一篇 - vue的介绍
三大主流框架: 1. Vue.js 是目前最火的一个前端框架,react是最流行的前端框架 (react除了开发网站,还可以开发手机app,Vue语法也是可以用于手机App开发的,需要借助于wexx) ...
- sql developer 17002报错无法连接
问题登场: 使用sql developer 登录oracle 时报错,错误码17002 解决办法: 右键,点击properties 属性,检查每一项配置,发现ip 是之前的ip,更改为database ...
- vlan技术简单了解
VLAN(虚拟局域网)是对连接到的第二层交换机端口的网络用户的逻辑分段,不受网络用户的物理位置限制而根据用户需求进行网络分段.一个VLAN可以在一个交换机或者跨交换机实现.VLAN可以根据网络用户的位 ...
- SQL Server 使用union all查询多个条件数据合并分组显示,同比统计
),a.created_yearmonth,) created_yearmonth, a.countaccount countaccount, a.yxsl yxsl, a.sccdsl sccdsl ...