Zend Expressive模塊快速開髮指南:構建只讀博客模塊
本文將分享一些Zend Expressive模塊開發技巧,幫助您快速構建一個功能完善的只讀博客模塊。請確保您已按照之前的教程設置好開發環境,包括安裝和配置Zend Expressive、Doctrine、Gulp以及抽象反射工廠(約需10分鐘)。
在本教程中,我們將快速構建一個簡單的只讀博客模塊(從數據庫中列出博客文章),展示Zend Expressive的快速開發能力。
模塊設置
在您的Expressive應用中運行以下命令:
<code class="language-bash">./vendor/bin/expressive module:create Blog</code>
這將生成Blog模塊的基本代碼,並自動將其註冊到您的應用程序和Composer自動加載器中。
Doctrine實體和數據庫表
接下來,創建Blog實體和數據庫表。首先,我們需要讓應用程序知道該模塊提供了Doctrine實體。
打開src/Blog/src/ConfigProvider.php
,添加以下代碼:
<code class="language-php">public function __invoke() { return [ 'dependencies' => $this->getDependencies(), 'doctrine' => $this->getDoctrine(), 'templates' => $this->getTemplates(), ]; } public function getDoctrine(): array { return [ 'driver' => [ 'orm_default' => [ 'drivers' => [ 'Blog\Entity' => 'blog_entity', ], ], 'blog_entity' => [ 'class' => \Doctrine\ORM\Mapping\Driver\SimplifiedYamlDriver::class, 'cache' => 'array', 'paths' => [ dirname(__DIR__) . '/config/doctrine' => 'Blog\Entity', ], ], ], ]; }</code>
在src/Blog/config/doctrine
目錄下創建BlogPost.orm.yml
文件,內容如下:
<code class="language-yaml">--- Blog\Entity\BlogPost: type: entity table: blog_post id: id: type: integer generator: strategy: AUTO fields: title: type: string length: 255 content: type: string length: 16777215</code>
運行./vendor/bin/doctrine orm:generate-entities src
。 由於Doctrine不支持PSR-4標準的目錄結構,需要將src/Blog/Entity
移動到src/Blog/src/Entity
。 然後運行以下命令創建數據庫表:
<code class="language-bash">./vendor/bin/doctrine orm:schema-tool:create</code>
您可以運行以下SQL語句填充數據庫表:
<code class="language-sql">INSERT INTO expressive.blog_post VALUES (null, 'Post 1', 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'), (null, 'Post 2', 'Mauris in libero laoreet, euismod lorem eget, tincidunt justo.'), (null, 'Post 3', 'Donec sed diam congue, ultrices tellus at, venenatis felis.');</code>
路由設置
Expressive模塊不直接註冊路由。我們需要使用一個小技巧來實現:創建src/Blog/src/Factory/RoutesDelegator.php
文件,內容如下:
<code class="language-php"><?php namespace Blog\Factory; use Blog\Action; use Psr\Container\ContainerInterface; use Zend\Expressive\Application; class RoutesDelegator { public function __invoke(ContainerInterface $container, $serviceName, callable $callback) { $app = $callback(); include __DIR__ . '/../../config/routes.php'; return $app; } }</code>
在src/Blog/src/ConfigProvider.php
的getDependencies()
方法中添加以下代碼:
<code class="language-php">'delegators' => [ \Zend\Expressive\Application::class => [ Factory\RoutesDelegator::class, ], ],</code>
創建src/Blog/config/routes.php
文件,添加博客路由:
<code class="language-php"><?php use Blog\Action; $app->get('/blog', Action\BlogPostListAction::class, 'blog_post_list'); $app->get('/blog/view/:blog_post_id', Action\BlogPostViewAction::class, 'blog_post_view');</code>
Action和模板
接下來,創建Action來處理路由請求,並創建模板文件。 (Action和模板代碼與原文相同,此處省略,請參考原文。)
創建、編輯和刪除功能的實現留作練習。
總結
本教程展示了使用Zend Expressive快速構建只讀博客模塊的簡易性。只需少量文件和幾分鐘的工作,即可創建一個從數據庫顯示文章的列表頁,並為後續添加/edit
和/delete
等路由做好準備。
(以下為原文FAQs部分,略作調整)
Zend Expressive快速開發常見問題
什麼是Zend Expressive? Zend Expressive是一個基於PHP的微型中間件框架,構建於Zend Stratigility之上,支持PSR-7中間件。
如何安裝Zend Expressive? 使用Composer:composer require zendframework/zend-expressive
Zend Expressive的優勢? 快速開發、簡單靈活,支持各種應用類型(微服務到單體應用),支持多種路由和模板系統。
如何在Zend Expressive中創建模塊? 在應用的src
目錄下創建新目錄,包含ConfigProvider
類,返回模塊配置數組(包含依賴項、路由和模板)。
如何在Zend Expressive中添加路由? 在模塊ConfigProvider
類的配置數組的routes
鍵中添加新條目。
如何在Zend Expressive中使用模板? Zend Expressive支持多種模板引擎(Twig、Plates、Zend View)。在ConfigProvider
類的配置數組的templates
鍵中添加條目。
如何在Zend Expressive中處理錯誤? Zend Expressive包含默認錯誤處理中間件。您可以創建自定義中間件來處理錯誤。
如何測試Zend Expressive應用? 使用PHPUnit。
如何部署Zend Expressive應用? 像任何其他PHP應用一樣部署,可以使用Apache、Nginx或PHP內置服務器。
哪裡可以找到更多關於Zend Expressive的資源? Zend Framework官方網站、Zend Expressive文檔和Zend Framework社區論壇。
以上是Zend表達模塊的快速發展的詳細內容。更多資訊請關注PHP中文網其他相關文章!