Zend Framework - Struttura dell'applicazione

In questo capitolo, comprendiamo la struttura dell'applicazione Zend Framework. La struttura delmyapp l'applicazione è la seguente:

├── 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

L'applicazione Zend Framework è composta da diverse cartelle. Sono i seguenti:

  • Application- Questa directory contiene la tua applicazione. Ospiterà il sistema MVC, nonché le configurazioni, i servizi utilizzati e il file di bootstrap.

  • Config - Questa directory contiene i file di configurazione di un'applicazione.

  • Data - Questa directory fornisce una posizione in cui memorizzare i dati dell'applicazione che sono volatili e possibilmente temporanei.

  • Module - I moduli consentono a uno sviluppatore di raggruppare una serie di controller correlati in un gruppo organizzato logicamente.

  • Public- Questa è la radice del documento dell'applicazione. Avvia l'applicazione Zend. Contiene anche le risorse dell'applicazione come JavaScript, CSS, immagini, ecc.

  • Vendor - Questa directory contiene le dipendenze del compositore.

Struttura dei moduli applicativi

Questa è la directory principale della tua applicazione. Zend Framework 2 introduce un sistema di moduli potente e flessibile per organizzare l'applicazione in modo efficiente. IlApplicationIl modulo dell'applicazione scheletro (myapp) fornisce bootstrap, errore e configurazione del routing all'intera applicazione. La struttura delApplication il modulo è come mostrato di seguito -

├── 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

Cerchiamo di coprire ciascuna di queste directory di moduli in dettaglio:

  • Application- Questa è la directory principale del modulo. Il nome della cartella corrisponderà al nome del modulo e il nome viene utilizzato anche come spazio dei nomi PHP di tutta la classe definita all'interno del modulo. Ospiterà il sistema MVC, nonché le configurazioni, i servizi utilizzati e il file di bootstrap.

  • Config - Configurazione indipendente del modulo.

  • Src - Principali logiche di business dell'applicazione.

  • View- Contiene file di progettazione / presentazione (HTML). Ad esempio, index.phtml.

  • src/Module.php- È il cuore del modulo. Funziona come un "front controller" per il modulo. Il processo Zendsrc/Module.php prima di elaborare qualsiasi classe PHP in questo modulo.

  • Application/config/module.config.php - È implementato per la configurazione del router e il caricamento automatico dei file.

  • Application/view/layout- I layout rappresentano le parti comuni di più visualizzazioni. Ad esempio, intestazione e piè di pagina. Per impostazione predefinita, i layout dovrebbero essere archiviati nel fileviews/layoutsfolder.

Tutti i moduli condividono la stessa o simile struttura di quella del modulo Applicazione sopra .