爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      MVC架构设计浅析

      首页 知识中心 其他 文章详情页

      MVC架构设计浅析

      2024-04-26 08:39:47 阅读次数:42

      mvc,spring

      摘 要:本文以图书管理系统为案例(当前主流框架SpringMVC的原理来分析MVC的设计理念等),深入浅出地分析常用的WEB设计模式MVC。将从MVC的历史、MVC每一层的作用,MVC能为我们带来什么好处又存在哪些问题以及MVC的前景如何等方面结合实际项目对该架构进行分析。通过本文你将从多个层面对MVC架构设计有一个初步的认识,让你快速走近MVC设计思想,通过实际项目的剖析以及图文交互的表达方式让您轻松理解MVC架构。

      关键词:MVC;SpringMVC;分层;视图;控制器;模型

      0  引言

      Web应用的根本都是从数据存储和检索数据并将其显示给用户。在用户更改数据之后,系统再将更新内容存储到数据存储中。因为关键的信息流发生在数据存储和用户界面之间,所以很多Web应用将数据和用户界面这两部分绑在一起,以减少编码量并提高应用程序性能。但是,这种看起来自然而然的方法有一些大问题。一是,用户界面的更改往往比数据存储系统的更改频繁得多。二是,这种情况下耦合往往会合并其他的业务逻辑。那么如何让 Web 应用程序的用户界面功能实现模块化,以便可以轻松地单独修改各个部分呢?面向对象的设计模式是Web设计经验的总结,MVC架构可以很好地解决上述问题。

      1  MVC简介

      MVC架构把数据处理,程序输入输出控制及数据显示分离开来,并且描述了不同部件的对象间的通信方式。使得软件可维护性,可扩展性,灵活性以及封装性大大提高;MVC(Model-View-Controller)把系统的组成分解为M(模型)、V(视图)、C(控制器)三种部件。视图表示数据在屏幕上的显示。控制器提供处理过程控制,它在模型和视图之间起连接作用。控制器本身不输出任何信息和做任何处理,它只负责把用户的请求转成针对Model的操作,和调用相应的视图来显示Model处理后的数据。三者之间关系如下图1 (MVC关系图)

      MVC架构设计浅析

       

       

      图1  MVC关系图

      2 为什么要使用MVC

      用户界面逻辑的更改往往比业务逻辑频繁,尤其是在基于Web的应用程序中。例如,可能添加新的用户界面页,或者可能完全打乱现有的页面布局。对显示的更改,尽可能地不要影响到数据和业务逻辑。

      目前大部分Web应用都是将数据代码和表示混在一起。经验比较丰富的开发者会将数据从表示层分离开来,但这通常不是很容易做到的,它需要精心的计划和不断的尝试。MVC从根本上强制性的将它们分开。尽管构造MVC应用需要一些额外的工作,但它带来的好处是毋庸置疑的。

      2.1 提高代码重用率

      最重要的一点就是多个视图可以共享同一个模型,把视图表达和底层数据分离。不论用户想要什么视图,只需要修改视图的模式,而数据可以根据接口自由传递,避免了同时修改视图和数据部分代码的困难,提高了代码的可重用性。

      2.2 提高程序可维护性

         因为模型是自包含的,并且与控制器和视图相分离,所以很容易改变数据层和业务规则。例如,把数据库从MySQL移植到Oracle,或者把基于RDBMS数据源改变到LDAP,只需改变模型即可。一旦正确的实现了模型,不管数据来自哪里,视图都会正确的显示它们。MVC架构的运用,使得程序的三个部件相互对立,大大提高了程序的可维护性。

      2.3 有利于团队开发

      在开发过程中,可以更好的分工,更好的协作。有利于开发出高质量的软件。良好的项目架构设计,将减少编码工作量 :采用MVC结构 + 代码生成器,是大多数Web应用的理想选择。部分模型(Model)、和存储过程一般可用工具自动生成。控制(Controller)器比较稳定,一般由于架构师(也可能是有经验的人)完成;那么整个项目需要手动编写代码的地方就只有视图(View)了。在这种模式下,个人能力不在特别重要,只要懂点语法基础的人都可以编写,无论项目成员写出什么样的代码,都在项目管理者的可控范围内。即使项目中途换人,也不会有太大问题。在个人能力参差不齐的团队开发中,采用MVC开发是非常理想的。

      3 基于SpringMVC的案例分析

      系统采用了SpringBoot框架,而SpringBoot是对SpringMVC的扩展,本质上依然是MVC架构模式,下面将以此为例带你了解MVC的原理和实现过程。

      3.1 MVC的工作流程

      SpringMVC 是一种基于 Java 的实现 MVC 设计模型的请求驱动类型的轻量级 Web 框架属于SpringFrameWork的后续产品,已经融合在 Spring Web Flow 中。 

      MVC的工作流程: 用户通过视图层发送请求到服务器,在服务器中请求被Controller接收,Controller调用相应的Model层处理请求,处理完毕将结果返回到Controller,Controller再根据请求处理的结果找到相应的View视图,渲染数据后最终响应给浏览器。

      3.2 SpringMVC实现原理

      先看一张原理图(图2 SpringMVC原理图)首先用户发起请求,请求被DispatcherServlet拦截,拦截之后去寻找请求对应的映射器。DispatcherServlet是核心,一切的一切都是从拦截请求开始的,当请求被拦截时,SpringMVC会根据请求,去处理请求映射关系,从而找到该请求对应的控制器,把处理器的名字返回到DispatcherServlet,而后再由DispatcherServlet找到该控制器,控制器完成的工作主要是封装数据,返回用户需要的视图,视图返回后,由DispatcherServlet调用视图解析器(ViewResolver)来解析HandlerAdapter传递的逻辑视图名。(获得model and view 中的数据,解析视图名字,拼接视图路径)视图解析器将解析的逻辑视图名传给DispatcherServlet。DispatcherServlet根据视图解析器解析的视图结果,调用具体的视图。

       

      MVC架构设计浅析

       

      图2  SpringMVC原理图

      3.3 MVC项目目录结构

      在基于SpringMVC的图书管理系统中,该框架在文件目录上把MVC清晰地分为了三层目录结构,分别对应了数据模型层(完成控制层和数据库的交互,完全不用干涉视图层),控制层(通过控制器决定了视图层的用户需要得到什么数据,成为视图层和数据模型层的桥梁),视图层(专注于如何把控制层传来的数据更好的展示给用户),目录结构如下图3。

       

      MVC架构设计浅析

       

      MVC架构设计浅析

      图3  SpringMVC目录结构图

       

      3.4 MVC核心

      SpringMVC乃至整个MVC架构的核心在控制层,控制层起到了承上启下,交互的作用。控制层决定了什么样的数据要传给什么样的视图,下面介绍一下SpringMVC是如何实现控制层的。

      为了方便管理,控制层被进一步分解出服务层(Service)这一层主要负责数据的获取,Controller层只需要去调用Servie层获取数据,而不需要既关注数据又关注视图。结构如图4所示:

       

      MVC架构设计浅析

      图4 SpringMVC Controller层结构图

      4 MVC的优点和不足

      4.1 MVC的优点

      MVC的优点体现在以下几个方面:

      (1) 有利于团队开发分工协作和质量控制,降低开发成本。

      (2) 可以为一个模型在运行时同时建立和使用多个视图。变化-传播机制可以确保所有相关的视图及时得到模型数据变化,从而使所有关联的视图和控制器做到行为同步。

      (3) 视图与控制器的可接插性,允许更换视图和控制器对象,而且可以根据需求动态的打开或关闭、甚至在运行期间进行对象替换。

      (4) 模型的可移植性。因为模型是独立于视图的,所以可以把一个模型独立地移植到新的平台工作。需要做的只是在新平台上对视图和控制器进行新的修改。

      (5) 潜在的框架结构。可以基于此模型建立应用程序框架,不仅仅是用在设计界面的设计中。

      4.2 MVC的不足

      MVC的不足体现在以下几个方面:

      (1)增加了系统结构和实现的复杂性。对于简单的界面,严格遵循MVC,使模型、视图与控制器分离,会增加结构的复杂性,并可能产生过多的更新操作,降低运行效率。

      (2)视图对模型数据的访问效率低。视图可能需要多次调用Model才能获得足够的显示数据。

      (3)完全理解MVC并不是很容易。使用MVC需要精心的计划,由于它的内部原理比较复杂,所以需要花费一些时间去思考。 同时由于模型和视图要严格的分离,这样也给调试应用程序到来了一定的困难。 

      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.51cto.com/reliableyang/5651610,作者:靠谱杨的挨踢IT生活,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:你胆敢在case后面不加break试试?

      下一篇:PS文字工具

      相关文章

      2025-05-08 09:03:21

      基于spring+jsp+mysql实现的Java web论坛系统【源码+数据库+指导运行】

      本项目是一套基于spring+jsp+mysql实现的Java web论坛系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的Java学习者。

      2025-05-08 09:03:21
      Java , jsp , spring , 功能 , 源码
      2025-05-08 09:03:07

      spring Bean的作用域和生命周期

      spring Bean的作用域和生命周期

      2025-05-08 09:03:07
      Bean , method , spring , 作用域 , 配置文件
      2025-05-07 09:08:54

      springboot系列教程(十二):基于转账案例,演示事务管理操作

      springboot系列教程(十二):基于转账案例,演示事务管理操作

      2025-05-07 09:08:54
      spring , 事务 , 接口 , 管理器 , 配置
      2025-04-14 08:48:01

      Java注解实现之how to use path variable @PathVariable

      Java注解实现之how to use path variable @PathVariable

      2025-04-14 08:48:01
      Java , spring
      2025-04-14 08:45:36

      Java SpringBoot 应用使用命令行 mvn spring-boot run 启动的原理

      将应用程序打包为 jar 并使用嵌入式 HTTP 服务器的最大优势之一是可以像运行其他任何应用程序一样运行这些提供了 Web 功能的应用程序。 调试 Spring Boot 应用程序也很容易; 不需要任何特殊的 IDE 插件或扩展。

      2025-04-14 08:45:36
      jar , spring , 应用程序
      2025-04-09 09:11:38

      spring boot设置session超时时长(自定义spring boot session超时时长)

      spring boot设置session超时时长(自定义spring boot session超时时长)

      2025-04-09 09:11:38
      boot , session , spring , 设置 , 超时
      2025-03-25 08:08:59

      spring boot项目设置默认访问路径(页面)方法,包括spring boot 2.0及以上版本实现方法

      spring boot项目设置默认访问路径(页面)方法,包括spring boot 2.0及以上版本实现方法

      2025-03-25 08:08:59
      boot , spring , 代码 , 访问 , 页面 , 默认
      2025-03-25 08:08:18

      spring boot整合mybatis和hikariCP时遇到 jdbcUrl is required with driverClassName 错误的解决方法

      spring boot整合mybatis和hikariCP时遇到 jdbcUrl is required with driverClassName 错误的解决方法

      2025-03-25 08:08:18
      jdbc , spring , url , 数据库 , 数据源 , 配置文件
      2025-03-25 08:08:18

      深入起步依赖(以spring-boot-starter-web为例)

      深入起步依赖(以spring-boot-starter-web为例)

      2025-03-25 08:08:18
      boot , pom , spring , Spring , 依赖
      2025-03-25 08:08:18

      ssm(Spring+Spring mvc+mybatis)Service层接口——IDeptService

      ssm(Spring+Spring mvc+mybatis)Service层接口——IDeptService

      2025-03-25 08:08:18
      mvc , mybatis , Service , Spring
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5256204

      查看更多

      最新文章

      spring boot设置session超时时长(自定义spring boot session超时时长)

      2025-04-09 09:11:38

      spring学习(ApplicationContext与BeanFactory实例化对象的基本流程与区别)(Bean工厂与IOC容器)(spring-IOC思想)

      2025-01-06 08:42:37

      spring+mybatis启动NoClassDefFoundError异常分析三部曲之二:定位错误

      2024-11-20 09:46:57

      spring boot 自定义过滤器链

      2024-11-05 08:30:44

      解决java.lang.IllegalArgumentException: Could not resolve placeholder ‘xxx‘ in value ““问题

      2024-09-25 10:14:48

      class java.time.LocalDateTime cannot be cast to class java.util.Date

      2024-09-25 10:14:48

      查看更多

      热门文章

      axios&spring前后端分离传参规范总结

      2023-05-22 08:09:06

      Bean的作用域

      2023-06-07 07:31:19

      Content type ‘application/x-www-form-urlencoded;charset=UTF-8‘ not supported错误的多种解决方法及说明Content-Type

      2024-09-25 10:14:21

      [spring学习]10、AOP思想提出

      2024-09-25 10:13:34

      [手写spring](5)实现AOP机制(完结)

      2023-07-03 09:13:10

      nested exception is org.apache.ibatis.type.TypeException: Could not set parameters for mapping错误的决方法

      2024-09-25 10:14:21

      查看更多

      热门标签

      linux java python javascript 数组 前端 docker Linux vue 函数 shell git 节点 容器 示例
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      Cause: org.apache.ibatis.type.TypeException: Error setting non null for xxx with JdbcType错误的详细解决方法

      拷贝对象工具类(对象赋值)copyProperties——为null不复制

      axios&spring前后端分离传参规范总结

      MyBatis-Plus通用枚举

      解决 No active profile set, falling back to 1 default profile: “default“问题以及如何查看spring boot版本号

      springmvc参数设置默认值,多地址请求

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号