《JavaEE进阶》----10.<SpringMVC应用分层:【三层架构】>

2024-09-04 08:52

本文主要是介绍《JavaEE进阶》----10.<SpringMVC应用分层:【三层架构】>,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇博客我们主要讲解

1.应用的分层:三层架构

2.Spring MVC和三层架构的区别和联系

3.软件设计原则:高内聚低耦合

4.应用分层的好处

5.通过应用分层后的代码示例

一、三层架构简介

阿里开发手册中,关于工程结构部分,定义了常见工程的应用分层结构:

上图的表示层,也叫做表现层。

解释概念 

1.表现层(Controller):展示数据结果和接收用户指令的,是最靠近用户的一层;

2.业务逻辑层(Service):处理业务逻辑,里面有复杂业务的具体实现。

3.数据层(Mapper/Dao):存储和管理与应用程序的相关的数据。

二、Spring MVC和三层架构的区别和联系

SpringMVC

三层架构 

 联系

二者其实是从不同角度对软件工程进行了抽象。 

MVC模式强调数据视图分离,将数据展示数据处理分开,通过控制器对两者进行组合.

三层架构强调不同维度数据处理的高内聚和低耦合,将交互界面,业务处理和数据库操作的逻辑分开.角度不同也就谈不上互相替代了,在日常的开发中可以经常看到两种共存的情况,比如我们设计模型层的时候往往也会拆分出业务逻辑层(Service层)和数据访问层(Dao层)。 

我的理解

区别

MVC架构模式组成:模型(Model)、视图(View)、控制器(Controller)

三层架构将业务应用分为:表现层、业务逻辑层、数据访问层。

Spring MVC:是对MVC思想在Spring框架中的一种实现。

三层架构是对代码处理的不同的逻辑功能的封层。

我觉得他们是两个独立的思想。

MVC是站在前后端共同开发时,对开发的理解。V对应前端,MC对应后端。

而如今我们已经前后端分离进行开发,因此实际上MVC的思想其实是有点过时的。

三层结构就是对我们纯后端代码的分层。

联系

但是他们有共同的目的,就是使我们开发程序更加的清晰有条理。

从概念上讲:二者都是软件工程领域中的架构模式。

并且三层架构中的表现层,对应MVC的视图和控制器,

而MVC中的模型对应三层架构的业务逻辑层,数据层,实体类。

二者的目的是相同的,都是"解耦,分层,代码复用"

三、软件设计原则:高内聚低耦合

高内聚低耦合矛盾吗?

不矛盾

高内聚:指的是一个模块中各个元素之间的联系的紧密程度。

低耦合:指的是各个模块之间的紧密程度。

比如一个企业中,各个部门关联关系要尽可能小,一个部门发生问题,要尽可能降低对其他部门的影响,就是低耦合。

但是部门员工关系要尽量紧密,遇到问题一起解决。这叫高内聚。

比如人体的各个部位中,手、脚、胳膊、腿之间的影响比较小,使得当手受伤,对其他部位影响很小,这就是低耦合。

而人体中,肌肉、骨骼、肌腱等需要相互配合,才能使得人们可以灵活运动。这就需要高内聚,紧密相连。

四、应用分层的好处

1.降低层与层之间的依赖,结构更加的明确,利于各层逻辑的复用。

2.开发人员可以只关注整个结构中的其中某一层,极大的降低了维护成本和维护时间

3.可以很容易的用新的实现来替换原有层次的实现

4.利于标准化。

五、通过应用分层后的代码示例

比如我们写的图书管理系统。如今我们主框架创建三个软件包。

1.Controller

 

2.Service

 

3. Mapper

这篇关于《JavaEE进阶》----10.<SpringMVC应用分层:【三层架构】>的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1135561

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取