Zend Framework - Tworzenie modułu

W tym rozdziale dowiemy się, jak stworzyć moduł oparty na MVC w Zend Framework. Utwórzmy moduł o nazwie asTutorial aby zrozumieć proces tworzenia modułu.

  • Utwórz nową klasę PHP o nazwie Module wewnątrz katalogu –myapp / module / Tutorial / src / i zaimplementuj interfejs ConfigProviderInterface.

  • Zestaw Tutorial jako przestrzeń nazw dla Module klasa.

  • Napisz funkcję publiczną getConfig w Module class i zwróć plik konfiguracyjny dla Tutorial Moduł.

Kompletny kod dla Module klasa jest następująca -

<?php  
namespace Tutorial; 
use Zend\ModuleManager\Feature\ConfigProviderInterface;
class Module implements ConfigProviderInterface { 
   public function getConfig() {    
      return include __DIR__ . '/../config/module.config.php'; 
   }    
}

Skonfiguruj Tutorial moduł w composer.json pod autoload sekcji przy użyciu następującego kodu.

"autoload": { 
   "psr-4": { 
      "Application\\": "module/Application/src/", 
      "Tutorial\\": "module/Tutorial/src/" 
   } 
}

Zaktualizuj aplikację za pomocą kompozytora update polecenie, jak pokazano poniżej.

composer update

Plik composer polecenie wykona niezbędne zmiany w aplikacji i wyświetli dzienniki w wierszu polecenia, jak pokazano poniżej -

Loading composer repositories with package information 
Updating dependencies (including require-dev) 
   - Removing zendframework/zend-component-installer (0.3.0) 
   - Installing zendframework/zend-component-installer (0.3.1) 
   Downloading: 100%           
   
   - Removing zendframework/zend-stdlib (3.0.1) 
   - Installing zendframework/zend-stdlib (3.1.0) 
   Loading from cache  
   
   - Removing zendframework/zend-eventmanager (3.0.1) 
   - Installing zendframework/zend-eventmanager (3.1.0) 
   Downloading: 100%           
   
   - Removing zendframework/zend-view (2.8.0) 
   - Installing zendframework/zend-view (2.8.1) 
   Loading from cache  
   
   - Removing zendframework/zend-servicemanager (3.1.0) 
   - Installing zendframework/zend-servicemanager (3.2.0) 
   Downloading: 100%           
   
   - Removing zendframework/zend-escaper (2.5.1) 
   - Installing zendframework/zend-escaper (2.5.2) 
   Loading from cache  
   
   - Removing zendframework/zend-http (2.5.4) 
   - Installing zendframework/zend-http (2.5.5) 
   Loading from cache  
   
   - Removing zendframework/zend-mvc (3.0.1) 
   - Installing zendframework/zend-mvc (3.0.4) 
   Downloading: 100%          
   
   - Removing phpunit/phpunit (5.7.4) 
   - Installing phpunit/phpunit (5.7.5) 
   Downloading: 100%           

Writing lock file 
Generating autoload files

Utwórz plik konfiguracyjny modułu „module.config.php” w /config/ z następującym kodem -

<?php  
namespace Tutorial;  
   
use Zend\ServiceManager\Factory\InvokableFactory; 
use Zend\Router\Http\Segment;  
return [ 
   'controllers' => [ 
      'factories' => [Controller\TutorialController::class => InvokableFactory::class,], 
   ],
   'view_manager' => [ 
      'template_path_stack' => ['tutorial' => __DIR__ . '/../view',], 
   ], 
];

Plik konfiguracyjny składa się z trzech części i są one następujące -

  • Controller configuration - Określ kontrolery dostępne w module.

  • Routing configuration - Określ, w jaki sposób kontrolery w module mają być rozwiązywane na adresy URL.

  • View configuration - Określ konfigurację związaną z wyświetlaniem silnika, taką jak lokalizacja widoków itp.

Skonfiguruj Tutorial moduł w pliku konfiguracyjnym na poziomie aplikacji - myapp / config / modules.config.php.

return ['Zend\Router', 'Zend\Validator', 'Application', 'Tutorial'];

Uruchom aplikację, wykonując composer serve w katalogu głównym folderu aplikacji.

Pomyślnie dodaliśmy nowy moduł, ale nadal musimy dodać Controller, Routing i Views aby pomyślnie uruchomić Tutorial moduł.