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
定义了更高级别的接口,使子系统更易于使用。再也不会忘记任何一步。