01 系统架构
系统架构是指,整合应用系统程序大的结构。经常提到的系统结构有两种:三层架构与 MVC。这两种结构既有区别,又有联系。但这两种结构的使用,均是为了降低系统模块间的耦合度
02 三层架构
三层架构是指:视图层 View、服务层 Service,与持久层 DAO。它们分别完成不同的功能
- View 层:用于接收用户提交请求的代码
- Service 层:系统的业务逻辑主要在这里完成
- DAO 层:直接操作数据库的代码
为了更好的降低各层间的耦合度,在三层架构程序设计中,采用面向抽象编程。即上层对下层的调用,是通过接口实现的。而下层对上层的真正服务提供者,是下层接口的实现类。服务标准(接口)是相同的,服务提供者(实现类)可以更换。这就实现了层间解耦合
拓展:
- 业务分类:简单业务指只开启一个事务;普通业务指开启三个事务;复杂业务指开启七个事务
- 提聚降耦:一个类只做一件事;一个方法只做一件事;写且只写一次
03 MVC架构
简述:MVC,即 Model 模型(对用户提交请求进行计算的模块,分为数据模型Entity/数据承载 Bean:专门用户承载业务数据的,如 Student、User 等和业务模型Service/业务处理 Bean:Service 或 Dao 对象, 专门用于处理用户提交请求的)、View 视图(为用户提供使用界面,与用户直接进行交互),及 Controller 控制器
演变:以前都是Servlet服务器小程序处理业务逻辑和页面展示(out.print);现在使用MVC架构后,将页面展示分离为JSP(V,其实JSP就是Servlet,故建议不适用其小脚本<%%>来降低耦合度),将业务逻辑专门交由Servlet处理©
工作流程:
- 用户通过 View 页面向服务端提出请求,可以是表单请求、超链接请求、AJAX 请求等
- 服务端 Controller 控制器接收到请求后对请求进行解析,找到相应的 Model 对用户请求进行处理
- Model 处理后,将处理结果再交给 Controller
- Controller 在接到处理结果后,根据处理结果找到要作为向客户端发回的响应 View 页面。页面经渲染(数据填充)后,再发送给客户端。
三层架构 + MVC 示意图:
拓展:基础设计原则、面向对象设计原则、重构原则(事不过三、三则重构,提取方法、提起类)
推荐书籍:《重构-改善既有代码的设计》、《人月神话》
04 三层架构MVC示例
简介:本例以登录为例,因为其业务逻辑完备,其通常又是独立的系统,甚至还会拆分成各种服务
过程:编程过程应该按照TDD(测试驱动编程)从下往上进行书写代码
拓展:HttpServlet中doGet()与doPost()区别
- get传参数方式是明文;post传参数方式是密文
- get参数规模有限制;post无限制
- get参数在url中;post在请求中
- post可以上传文件(流)
- get语义为获取数据;post语义为提交数据
- post请求有两次(首次询问能否加入数据,其次再传递参数);get只有一次(效率高)
注意:实际项目开发时常用如下方式部署项目
代码地址:Gitee【三层架构+MVC模式实现】