PHP前端开发

Laravel 领域驱动设计 (DDD) 简单指南

百变鹏仔 2天前 #PHP
文章标签 领域

您是否曾感觉到,随着 laravel 项目的发展,事情开始变得有点失控?控制器变得臃肿,模型开始做太多事情,突然之间,你的代码库就像你几个月来一直想组织的抽屉一样。这就是 领域驱动设计 (ddd) 可以介入并让您的生活更轻松的地方。

ddd 是一种设计应用程序的方法,使其结构与您在现实世界中解决的问题紧密结合。随着项目的发展,它有助于使您的代码更清晰、更具可扩展性并且更易于管理。

在本指南中,我们将引导您了解 laravel 中的 ddd 基础知识,解释如何实现它,并向您展示一些现实世界的示例。

目录

  1. 什么是领域驱动设计(ddd)?
  2. 为什么在 laravel 中使用 ddd?
  3. ddd 的组成部分
  4. 在 laravel 中实现 ddd
  5. laravel 中 ddd 的优缺点
  6. 最后的想法

什么是领域驱动设计(ddd)?

在深入了解 laravel 细节之前,让我们先介绍一下 领域驱动设计 (ddd) 的全部内容。 ddd 是一种通过关注业务领域(您的软件正在解决的核心问题)来组织应用程序代码的方法。

不是围绕控制器或模型等技术概念来构建代码,而是围绕现实世界的概念来构建代码。这可能是订单、产品或客户等内容,具体取决于您的应用程序的用途。

简而言之,ddd 可帮助您构建反映现实世界流程的应用程序,使代码更易于理解和维护,尤其是随着代码的增长。

为什么在 laravel 中使用 ddd?

如果您熟悉 laravel 默认使用的 mvc(模型-视图-控制器)模式,您就会知道它对于大多数应用程序都很有效。但随着应用程序的扩展,mvc 模式可能会导致混乱的相互依赖的代码。 领域驱动设计通过使您的应用程序更容易扩展和维护来解决这个问题。

ddd 还将业务逻辑基础设施代码分开。这意味着您的应用程序逻辑不会与数据库或 api 之类的东西绑定,从而使以后更容易更换技术。

ddd 的组成部分

要了解 ddd 的工作原理,您需要了解其关键组件。让我们来分解一下:

实体

实体是您的域中具有独特身份的对象。例如,订单是一个实体,因为每个订单都是唯一的。

// app/domain/order/order.phpclass order {    private $id;    private $status;    public function __construct($id, $status) {        $this->id = $id;        $this->status = $status;    }    // getter and other business logic}

值对象

值对象是一个没有标识的对象,但它代表一个概念。例如,money 对象代表一个值,但不需要唯一的 id。

// app/domain/order/money.phpclass money {    private $amount;    private $currency;    public function __construct($amount, $currency) {        $this->amount = $amount;        $this->currency = $currency;    }    public function getformatted() {        return "{$this->amount} {$this->currency}";    }}

存储库

存储库 处理获取和持久化实体等域对象。存储库管理数据访问,而不是直接与数据库交互的域对象。

// app/domain/order/orderrepositoryinterface.phpinterface orderrepositoryinterface {    public function findbyid($id): ?order;    public function save(order $order): void;}// app/infrastructure/order/eloquentorderrepository.phpclass eloquentorderrepository implements orderrepositoryinterface {    public function findbyid($id): ?order {        // fetch order using eloquent    }    public function save(order $order): void {        // save order using eloquent    }}

服务

服务 处理业务逻辑,例如创建订单或处理付款。您无需将此逻辑放入控制器中,而是将其封装在服务中。

// app/domain/order/createorderservice.phpclass createorderservice {    public function execute($data) {        $order = new order($data['id'], $data['status']);        // business logic for creating an order    }}

在 laravel 中实现 ddd

现在您已经了解了关键组件,让我们通过一些实际示例来看看如何在 laravel 中实现 ddd。

示例1:构建订单管理系统

假设您正在为电子商务网站构建订单管理系统。以下是 ddd 如何帮助您组织代码:

  1. 实体:您将有一个订单实体来表示每个订单,并具有 id 和 status 等属性。
  2. 值对象:您可以创建一个 money 值对象来表示价格。
  3. 存储库:您将创建一个 orderrepository 来在数据库中获取和存储订单。
  4. 服务:createorderservice 将处理创建新订单的逻辑。

这是基本流程:

// app/http/controllers/ordercontroller.phpclass ordercontroller {    private $createorderservice;    public function __construct(createorderservice $createorderservice) {        $this->createorderservice = $createorderservice;    }    public function store(request $request) {        $this->createorderservice->execute($request->all());        return response()->json(['message' => 'order created!']);    }}

示例 2:管理用户订阅

假设您正在管理 saas 平台的用户订阅。使用 ddd,您可以创建:

以下是处理订阅续订的方法:

// app/Domain/Subscription/RenewSubscriptionService.phpclass RenewSubscriptionService {    private $subscriptionRepository;    public function __construct(SubscriptionRepositoryInterface $subscriptionRepository) {        $this->subscriptionRepository = $subscriptionRepository;    }    public function renew($subscriptionId) {        $subscription = $this->subscriptionRepository->findById($subscriptionId);        $subscription->renew();        $this->subscriptionRepository->save($subscription);    }}

laravel 中 ddd 的优缺点

优点:

缺点:


最后的想法

laravel 中的 ddd 可能看起来令人畏惧,但是一旦你开始从业务领域而不是技术层角度思考,它就开始有意义了。这一切都是为了随着项目的发展保持代码整洁、可维护和可扩展。

从小事做起。使用 ddd 原则重构应用程序中的一项功能,看看效果如何。随着时间的推移,您将开始欣赏它带来的组织性和清晰度。

祝你好运,编码愉快!