PHP设计模式——门面模式

  • 2019 年 11 月 24 日
  • 筆記

为子系统中的一组接口提供统一的接口。Facade(门面)定义了一个更高级别的界面,使子系统更易于使用。

作为一名软件开发人员,我们所有人要做的一个主要任务就是部署。与我们所有人相似,当Eric刚开始作为开发人员的职业生涯时,他是手动完成所有部署工作的。他使用一种非常标准的方法来做到这一点:将服务器设置为脱机模式,传输源代码文件,更新数据库的架构以及将服务器设置为联机:

$server->offline();  $fileSystem->transferFiles();  $database->updateSchema();  $server->online();

这似乎是理想的方法。这个过程很简单明了。但是,随着越来越多的程序被引入,人为错误开始发生。新程序(例如在传输文件之前运行测试)变得更加频繁。有一次,他的同事在当天失业后看到埃里克(Eric)赶回办公室。他们问:“嗨,Eric!急什么?” Eric毫不犹豫地答道:“我忘了在将服务器重新设置为联机之前先更新数据库!”众所周知,人为错误是不可避免的,但可以将其最小化。我们意识到我们需要更好的解决方案 。

如果我们能够将所有过程封装到一个简单的方法中会怎样?这样一来,我们就不必担心忘记任何步骤。要更新程序,我们只需要就地更新即可。在这种情况下,我们可以使用门面模式(Facade Pattern)。

让我们看看它在代码中的表示:

class DeployFacade  {      private $server = null;      private $fileSystem = null;      private $database = null;      public function  __construct(Server $server, FileSystem $fileSystem, Database $database)      {          $this->server = $server;          $this->fileSystem = $fileSystem;          $this->database = $database;      }        public function deploy()      {          $this->server->offline();          $this->transferFiles();          $this->updateSchema();          $this->online();      }  }

现在,每次Eric需要进行部署时,他只需要执行以下操作:

$deployFacade->deploy();

您可能会很快意识到,实际上我们已经在使用与DeployFacade类似的东西,即部署脚本。这是门面模式(Facade Pattern)的一个示例。在我们的示例中,通过使用门面模式(Facade Pattern),它为子系统中的一组接口(服务器,文件系统和数据库)提供了统一的接口(DeployFacade)。 Facade定义了更高级别的接口,使子系统更易于使用。再也不会忘记任何一步。