22.DDD与MVC

发布于:2024-12-18 ⋅ 阅读:(62) ⋅ 点赞:(0)

学习视频来源:DDD独家秘籍视频合集 https://space.bilibili.com/24690212/channel/collectiondetail?sid=1940048&ctype=0

MVC

在这里插入图片描述
View负责生成给用户查看和操作的页面,并把用户的操作翻译给Controller,Controller翻译用户执行动作给Model。Model负责业务处理,提供View渲染需要的数据。

DDD六边形架构

在这里插入图片描述
这种架构本质上是只分两块,领域核心和非领域核心。

MVC和DDD的关系

MVC和DDD二者是没有关系的。MVC是解决应用程序中业务逻辑、数据和界面显示的耦合问题,使得开发和维护更加清晰和简单‌。DDD是解决业务逻辑问题。一个软件系统中可以使用DDD+MVC,也可以使用DDD但不使用MVC(DDD-MVC),也可以使用MVC但不使用DDD(MVC-DDD),也可以既不使用MVC也不使用DDD。

DDD+MVC

在这里插入图片描述
DDD+MVC架构中,Model的职责委托给领域核心和查询模型去实现。这种典型的架构有:

  • JSP(V)+ Servlet(C) + EJB(M)
  • JSP(V)+ Struts (C)+ Spring Bean(M)
  • JSF(V) +EJB(CM)
  • freemarker/thymeleaf/velocity(V) + Spring MVC(C) + Spring Bean(M)
    Mode功能使放在EJB和Spring Bean中实现。

DDD-MVC

  • 没有MVC,只有对外接口,用于接受外部请求。这里的接口一般是HTTP接口或者webSocket接口。
  • 处理请求被翻译成执行领域命令,有领域核心。
  • 在前端大发展之后 (Ajax React Vue) MVC在服务端就逐渐不流行了,用户交互都是交给前端执完成。

MVC-DDD

  • 有MVC
  • Model不使用领域模型,没有领域模块。
  • Model负责直接数据库操作,页面需要渲染需要哪个数据,就直接从数据库表里查。对页面进行操作的时候,也是直接翻译成对数据库进行操作。

事务脚本大泥球

在这里插入图片描述
既没有MVC,也没有DDD。这种架构虽然不好,但目前最为常见。用户交互都是交给前端去做,服务端不管。Dao相当于一条一条的SQL语句,Service是事务脚本,主要对这些SQL排个序,对查询结果进行组装。Contorller只是对Client的请求参数的翻译。这种架构也不是分层架构,因为Contorller、Service、Dao可能共用一些类等。如果将三者分别作为单独的JAR包,可能无法实现单向编译。


网站公告

今日签到

点亮在社区的每一天
去签到