Skip to content

3)MVC 模型

An image

在业务流程设计中,采用 分层架构(Layered Architecture)是一种常见的设计模式,它帮助将应用程序的不同职责分离,使得系统更加易于维护、扩展和测试。在这种架构下,通常会将应用程序划分为多个层,每一层都负责处理特定的任务。针对业务流程设计,常见的分层架构包括以下三个主要层级:Controller 层、Service 层和 Repository 层

1. Controller 层(处理请求)

功能:Controller 层负责接收和处理外部的 HTTP 请求,通常是用户发起的请求。它充当了应用程序与外部世界之间的桥梁,将请求路由到适当的服务,并根据服务的处理结果返回响应给客户端。Controller 层主要负责请求的验证、参数处理和响应生成。

职责

  • 接收和解析请求(通常是 HTTP 请求)。
  • 校验请求参数(如是否符合业务规则、是否完整等)。
  • 调用相应的 Service 层处理业务逻辑。
  • 返回适当的响应(如成功、失败信息,数据,错误码等)。

技术栈

  • 在 Web 应用中,Controller 层通常是由框架(如 Express.js、Spring MVC、Flask、Django 等)提供支持的。

示例

javascript
// Express.js Controller 示例
const productService = require("./services/productService");

app.get("/products", async (req, res) => {
  try {
    const products = await productService.getAllProducts();
    res.status(200).json(products);
  } catch (error) {
    res.status(500).json({ error: "Internal Server Error" });
  }
});

2. Service 层(执行业务逻辑)

功能:Service 层处理应用程序的业务逻辑,它位于 Controller 层和 Repository 层之间,负责执行业务规则、数据转换、流程控制等操作。Service 层接收来自 Controller 层的请求数据,进行业务处理后,调用 Repository 层与数据库交互,并将结果返回给 Controller 层。Service 层充当了中介,确保业务逻辑的独立性和灵活性。

职责

  • 接收 Controller 层传入的数据,进行必要的业务处理。
  • 调用 Repository 层访问数据库或其他数据源。
  • 对数据进行转换和封装,返回给 Controller 层。
  • 控制事务和错误处理(如回滚事务、异常捕获等)。

技术栈

  • Service 层的实现通常是业务逻辑的集中所在,使用 JavaScript/TypeScript、Java、Python、Go 等语言实现。

示例

javascript
// Service 层示例
const productRepository = require("../repositories/productRepository");

const getAllProducts = async () => {
  // 可能需要进行一些业务处理,如排序、过滤等
  const products = await productRepository.findAll();
  return products;
};

module.exports = {
  getAllProducts,
};

3. Repository 层(与数据库交互)

功能:Repository 层负责与数据库进行交互,封装所有的数据库操作。它将数据访问的细节隐藏在内部,只提供简单的接口供 Service 层调用。Repository 层将查询、插入、更新和删除等数据库操作封装成方法,确保数据库的操作与业务逻辑的分离。

职责

  • 与数据库进行交互,执行数据的查询、插入、更新和删除操作。
  • 封装复杂的 SQL 查询,提供简单的接口供 Service 层调用。
  • 处理数据的持久化(如将对象存储到数据库中)。

技术栈

  • Repository 层通常使用数据库相关技术栈,如 ORM(如 Sequelize、TypeORM、Hibernate、Mongoose)或原生 SQL 查询。

示例

javascript
// Repository 层示例
const db = require("../models"); // 假设使用 Sequelize ORM

const findAll = async () => {
  return await db.Product.findAll();
};

module.exports = {
  findAll,
};

业务流程设计的具体流程

  1. Controller 层处理请求:用户通过浏览器、移动应用或其他客户端发起 HTTP 请求(例如,GET、POST 请求)。Controller 层负责接收这些请求并验证请求参数。

    例如,用户请求所有商品的列表:

    • Controller 收到请求后,解析请求并调用相应的 Service 层来获取商品数据。
  2. Service 层执行业务逻辑:Service 层接收到来自 Controller 层的数据,执行具体的业务逻辑(如排序、分页、权限校验等),然后调用 Repository 层获取或修改数据。

    例如,Service 层获取所有商品数据并做一些业务处理(如排序、过滤)后,将数据返回给 Controller 层。

  3. Repository 层与数据库交互:Repository 层根据 Service 层的要求,执行数据库操作(如查询数据库,获取商品数据)并将结果返回给 Service 层。

    例如,Repository 层向数据库查询所有商品并返回结果。

  4. Controller 层返回响应:最终,Controller 层将 Service 层返回的数据(例如商品列表)包装成响应,返回给客户端(例如,前端页面)。

    例如,Controller 层将商品数据转换成 JSON 格式并返回给客户端。

总结

  • Controller 层:负责接收请求和返回响应,接入外部系统或用户。
  • Service 层:处理业务逻辑,保证业务流程的正确性和完整性。
  • Repository 层:负责与数据库进行交互,执行 CRUD 操作。

这种分层设计能够有效地实现关注点分离、提高系统的可维护性、可扩展性和测试性,使得每一层都有明确的职责,且层与层之间的耦合度较低。