Zend Framework - Estrutura do Aplicativo

Neste capítulo, vamos entender a estrutura da aplicação Zend Framework. A estrutura domyapp a aplicação é a seguinte -

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

O aplicativo Zend Framework consiste em diferentes pastas. Eles são os seguintes -

  • Application- Este diretório contém seu aplicativo. Ele irá abrigar o sistema MVC, bem como configurações, serviços usados ​​e seu arquivo de bootstrap.

  • Config - Este diretório contém os arquivos de configuração de um aplicativo.

  • Data - Este diretório fornece um local para armazenar dados de aplicativos que são voláteis e possivelmente temporários.

  • Module - Os módulos permitem que um desenvolvedor agrupe um conjunto de controladores relacionados em um grupo organizado logicamente.

  • Public- Esta é a raiz do documento do aplicativo. Ele inicia o aplicativo Zend. Ele também contém os ativos do aplicativo, como JavaScript, CSS, imagens, etc.

  • Vendor - Este diretório contém dependências do compositor.

Estrutura dos Módulos de Aplicação

Este é o diretório principal do seu aplicativo. Zend Framework 2 apresenta um sistema de módulo poderoso e flexível para organizar o aplicativo de forma eficiente. oApplicationO módulo do esqueleto do aplicativo (myapp) fornece bootstrapping, erro e configuração de roteamento para todo o aplicativo. A estrutura doApplication módulo é como mostrado abaixo -

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

Vamos cobrir cada um desses diretórios de módulo em detalhes -

  • Application- Este é o diretório raiz do módulo. O nome da pasta irá corresponder ao nome do módulo e o nome também é usado como o namespace PHP de todas as classes definidas dentro do módulo. Ele hospedará o sistema MVC, bem como as configurações, serviços usados ​​e seu arquivo de bootstrap.

  • Config - Configuração independente do módulo.

  • Src - Principal lógica de negócio da aplicação.

  • View- Contém arquivos de design / apresentação (HTML). Por exemplo, index.phtml.

  • src/Module.php- É o coração do módulo. Ele funciona como um “controlador frontal” para o módulo. O processo Zendsrc/Module.php antes de processar qualquer classe PHP neste módulo.

  • Application/config/module.config.php - É implementado para configuração do roteador e carregamento automático de arquivos.

  • Application/view/layout- Os layouts representam as partes comuns de várias visualizações. Por exemplo, cabeçalho e rodapé da página. Por padrão, os layouts devem ser armazenados noviews/layoutsfolder.

Todos os módulos compartilham a mesma estrutura ou estrutura semelhante ao módulo do aplicativo acima .