Zend Framework - Anwendungsstruktur

Lassen Sie uns in diesem Kapitel die Struktur der Zend Framework-Anwendung verstehen. Die Struktur dermyapp Anwendung ist wie folgt -

├── composer.json 
├── composer.lock 
├── CONDUCT.md 
├── config 
│   ├── application.config.php 
│   ├── autoload 
│   │   ├── development.local.php 
│   │   ├── development.local.php.dist 
│   │   ├── global.php 
│   │   ├── local.php.dist 
│   │   ├── README.md 
│   │   └── zend-developer-tools.local-development.php 
│   ├── development.config.php 
│   ├── development.config.php.dist 
│   └── modules.config.php 
├── CONTRIBUTING.md 
├── data 
│   └── cache 
│       └── module-classmap-cache.application.module.cache.php ├── docker-compose.yml 
├── Dockerfile 
├── LICENSE.md 
├── module 
│   └── Application 
│       ├── config 
│       ├── src 
│       ├── test 
│       └── view 
├── phpcs.xml 
├── phpunit.xml.dist 
├── public
│   ├── css 
│   │   ├── bootstrap.css 
│   │   ├── bootstrap.css.map 
│   │   ├── bootstrap.min.css 
│   │   ├── bootstrap.min.css.map 
│   │   ├── bootstrap-theme.css 
│   │   ├── bootstrap-theme.css.map 
│   │   ├── bootstrap-theme.min.css 
│   │   ├── bootstrap-theme.min.css.map 
│   │   └── style.css 
│   ├── fonts 
│   │   ├── glyphicons-halflings-regular.eot 
│   │   ├── glyphicons-halflings-regular.svg 
│   │   ├── glyphicons-halflings-regular.ttf 
│   │   ├── glyphicons-halflings-regular.woff 
│   │   └── glyphicons-halflings-regular.woff2 
│   ├── img 
│   │   ├── favicon.ico 
│   │   └── zf-logo-mark.svg 
│   ├── index.php 
│   ├── js 
│   │   ├── bootstrap.js 
│   │   ├── bootstrap.min.js 
│   │   └── jquery-3.1.0.min.js 
│   └── web.config 
├── README.md 
├── TODO.md 
├── Vagrantfile 
└── vendor     
├── autoload.php     
├── bin     
│   ├── phpunit -> ../phpunit/phpunit/phpunit     
│   ├── templatemap_generator.php -> ../zendframework/zend-
view/bin/templatemap_generator.php
│   └── zf-development-mode -> ../zfcampus/zf-development-mode/bin/zf-
development-mode 
├── composer     
│   ├── autoload_classmap.php     
│   ├── autoload_namespaces.php     
│   ├── autoload_psr4.php     
│   ├── autoload_real.php     
│   ├── ClassLoader.php     
│   ├── installed.json 
│   └── LICENSE     
├── container-interop 
│   └── container-interop     
├── doctrine 
│   └── instantiator     
├── myclabs 
│   └── deep-copy     
├── phpdocumentor     
│   ├── reflection-common     
│   ├── reflection-docblock 
│   └── type-resolver     
├── phpspec 
│   └── prophecy     
├── phpunit     
│   ├── php-code-coverage     
│   ├── php-file-iterator     
│   ├── php-text-template     
│   ├── php-timer     
│   ├── php-token-stream     
│   ├── phpunit 
│   └── phpunit-mock-objects     
├── sebastian     
│   ├── code-unit-reverse-lookup     
│   ├── comparator     
│   ├── diff     
│   ├── environment     
│   ├── exporter     
│   ├── global-state     
│   ├── object-enumerator
│   ├── recursion-context     
│   ├── resource-operations 
│   └── version     
├── symfony 
│   └── yaml     
├── webmozart 
│   └── assert     
├── zendframework     
│   ├── zend-component-installer     
│   ├── zend-config     
│   ├── zend-console     
│   ├── zend-dom     
│   ├── zend-escaper     
│   ├── zend-eventmanager     
│   ├── zend-http     
│   ├── zend-loader     
│   ├── zend-modulemanager     
│   ├── zend-mvc     
│   ├── zend-router     
│   ├── zend-servicemanager     
│   ├── zend-stdlib     
│   ├── zend-test     
│   ├── zend-uri     
│   ├── zend-validator 
│   └── zend-view 
└── zfcampus 
└── zf-development-mode  

73 directories, 55 files

Die Zend Framework-Anwendung besteht aus verschiedenen Ordnern. Sie sind wie folgt -

  • Application- Dieses Verzeichnis enthält Ihre Anwendung. Es enthält das MVC-System sowie Konfigurationen, verwendete Dienste und Ihre Bootstrap-Datei.

  • Config - Dieses Verzeichnis enthält die Konfigurationsdateien einer Anwendung.

  • Data - In diesem Verzeichnis können Anwendungsdaten gespeichert werden, die flüchtig und möglicherweise vorübergehend sind.

  • Module - Mit Modulen kann ein Entwickler eine Reihe verwandter Controller in einer logisch organisierten Gruppe gruppieren.

  • Public- Dies ist der Dokumentenstamm der Anwendung. Es startet die Zend-Anwendung. Es enthält auch die Assets der Anwendung wie JavaScript, CSS, Bilder usw.

  • Vendor - Dieses Verzeichnis enthält Composer-Abhängigkeiten.

Struktur der Anwendungsmodule

Dies ist das Hauptverzeichnis Ihrer Anwendung. Zend Framework 2 führt ein leistungsstarkes und flexibles Modulsystem ein, um die Anwendung effizient zu organisieren. DasApplicationDas Modul der Skeleton-Anwendung (myapp) bietet Bootstrapping-, Fehler- und Routing-Konfiguration für die gesamte Anwendung. Die Struktur derApplication Modul ist wie unten gezeigt -

├── module 
│   └── Application 
│       ├── config 
│       │   └── module.config.php 
│       ├── src 
│       │   ├── Controller 
│       │   │   └── IndexController.php 
│       │   └── Module.php 
│       ├── test 
│       │   └── Controller 
│       │       └── IndexControllerTest.php 
│       └── view 
│           ├── application 
│           │   └── index 
│           │       └── index.phtml 
│           ├── error 
│           │   ├── 404.phtml 
│           │   └── index.phtml 
│           └── layout 
│               └── layout.phtml

Lassen Sie uns jedes dieser Modulverzeichnisse im Detail behandeln -

  • Application- Dies ist das Stammverzeichnis des Moduls. Der Name des Ordners stimmt mit dem Namen des Moduls überein und der Name wird auch als PHP-Namespace aller im Modul definierten Klassen verwendet. Es enthält das MVC-System sowie Konfigurationen, verwendete Dienste und Ihre Bootstrap-Datei.

  • Config - Unabhängige Konfiguration des Moduls.

  • Src - Hauptgeschäftslogik der Anwendung.

  • View- Enthält HTML-Dateien (Design / Präsentation). Zum Beispiel index.phtml.

  • src/Module.php- Es ist das Herzstück des Moduls. Es fungiert als „Front-Controller“ für das Modul. Der Zend-Prozesssrc/Module.php Datei vor der Verarbeitung von PHP-Klassen in diesem Modul.

  • Application/config/module.config.php - Es ist für die Routerkonfiguration und das automatische Laden von Dateien implementiert.

  • Application/view/layout- Layouts repräsentieren die gemeinsamen Teile mehrerer Ansichten. Zum Beispiel Seitenkopf und Fußzeile. Standardmäßig sollten Layouts in der gespeichert werdenviews/layoutsfolder.

Alle Module haben dieselbe oder eine ähnliche Struktur wie das oben genannte Anwendungsmodul .