Anwendungs- und Bootstrap-Nutzung im Zend Framework

不言
Freigeben: 2023-04-01 09:24:01
Original
1979 Leute haben es durchsucht

Dieser Artikel stellt hauptsächlich die Verwendung von Anwendung und Bootstrap im Zend Framework-Tutorial vor. Er analysiert die Funktionen von Anwendung und Bootstrap im Detail in Form von Beispielen, Verwendungsfähigkeiten und zugehörigen Vorsichtsmaßnahmen. Freunde in Not können sich auf diesen Artikel beziehen 🎜>

Das Beispiel beschreibt die Verwendung von Application und Bootstrap im Zend Framework-Tutorial. Geben Sie es wie folgt als Referenz an alle weiter:

In einer MVC-Anwendung müssen wir eine Datenbankverknüpfung initialisieren und einrichten, Ansichten und Ansichtsassistenten konfigurieren, das Layout konfigurieren, zugehörige Plug-Ins registrieren und Aktionsassistenten registrieren usw. Wir müssen die Konfigurations- und Vorbereitungsarbeiten einzeln abschließen. Manchmal sind möglicherweise einige Initialisierungsvorgänge erforderlich, in einigen Fällen sind diese Initialisierungen jedoch möglicherweise nicht erforderlich. Zend_Application kann diese Vorgänge nicht nur abschließen, sondern auch diese Konfigurations- und Initialisierungsaufgaben einheitlicher und geordneter gestalten und die Wiederverwendbarkeit erhöhen.

Die Verwendung von Zend_Application kann in drei Typen unterteilt werden:

Zend_Application: lädt die PHP-Umgebung, einschließlich include_paths und automatischem Laden, und instanziiert die Boot-Klasse.

Zend_Application_Bootstrap: Stellt eine Schnittstelle für Boot-Klassen bereit.

Zend_Application_Bootstrap_Bootstrap vervollständigt die häufigsten Funktionen, die der Bootvorgang bereitstellen muss, einschließlich Abhängigkeitsprüfung und Laden von Boot-Ressourcen bei Bedarf.

Zend_Application_Resource bietet eine On-Demand-Funktion zum Laden von Ressourcen

Entwickler können je nach Bedarf Zend_Application_Bootstrap_Bootstrap erben oder die Zend_Application_Bootstrap_Bootstrapper-Schnittstelle implementieren. Zend_Application wird in die Eintragsdatei (zum Beispiel public/index.php) geladen und entsprechend den Boot-Optionen und der aktuellen Umgebungskonfiguration instanziiert.

Die Boot-Optionen umfassen die angegebene Boot-Klassendatei und den Boot-Klassenpfad. Die Optionen lauten wie folgt:

Erforderliche include_paths

Die automatische Ladefunktion lädt zusätzlich den registrierten Namespace

php.ini-Initialisierungseinstellungen

Geben Sie den Bootstrap-Klassennamen an, wenn er nicht „Bootstrap“ ist.

Das Präfix-Schlüssel-Wert-Paar der Ressource stellt den Ressourcenpräfixnamen dar

Der Name oder Alias ​​der Ressourcenklasse

Zusätzlicher geladener Konfigurationsdateipfad

Zusätzliche Konfigurationsoptionen

Die Option kann ein Array oder ein Zend_Config-Objekt oder ein sein Konfigurationsdatei an einem bestimmten Ort

Bootstrapper

Die zweite Funktion von Zend_Application besteht darin, die Anwendung zu führen. Die spezifische Schnittstellen-API lautet wie folgt :

interface Zend_Application_Bootstrap_Bootstrapper
{
  public function __construct($application);
  public function setOptions(array $options);
  public function getApplication();
  public function getEnvironment();
  public function getClassResources();
  public function getClassResourceNames();
  public function bootstrap($resource = null);
  public function run();
}
Nach dem Login kopieren

API bietet hauptsächlich Nach der Konfiguration der Umgebung, dem Erhalten von Bootload-Ressourcen und dem Bootloader

können Sie die Schnittstelle implementieren oder Zend_Application_Bootstrap_BootstrapAbstract oder Zend_Application_Bootstrap_Bootstrap erben.

Ressource Methode

Die Ressourcenmethode, die die Schnittstelle Zend_Application_Bootstrap_BootstrapAbstract implementiert, muss den folgenden Regeln folgen. Der Methodentyp ist geschützt und das Präfix der Methode muss mit _init beginnen.

Wenn Sie Wenn Sie eine Ressourcenmethode laden und verwenden möchten, fügen Sie einfach den Ressourcennamen in bootstrap() hinzu. Der Ressourcenname ist die Ressourcenmethode ohne das Präfix _init.

Wenn Sie mehrere Ressourcenmethoden laden möchten, können Sie diese über ein Array angeben.

Zum Beispiel wird die Bootstrap-Klasse:

class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
{
  protected function _initFoo()
  {
    // ...
  }
  protected function _initBar()
  {
    // ...
  }
  protected function _initBaz()
  {
    // ...
  }
}
Nach dem Login kopieren

nur mit _initFoo() geladen:

$bootstrap->bootstrap('foo');
Nach dem Login kopieren

wird mit _initFoo() und _initBar() geladen:

$bootstrap->bootstrap(array('foo', 'bar'));
Nach dem Login kopieren

Laden und verwenden Sie alle Ressourcenmethoden, verwenden Sie bootstrap() ohne Parameter:

$bootstrap->bootstrap();
Nach dem Login kopieren

Neues first_web-Projekt

root@coder-671T-M:/mydev_src/zend_framework_learn/www# tree first_web /first_web/
├── application
│ ├── Bootstrap.php
│ ├── configs
│ │ └── application.ini
│ ├── Controller │ │ 🎜>│ _ ─ index.phtml
├── docs
│ └── README.txt
├── Bibliothek
├── öffentlich
│. └── Index. php
└── Tests
├── Anwendung
│ └── Controller
│ └── IndexControllerTest.php
├── bootstrap.php
├── Bibliothek
└── phpunit.xml
16 Verzeichnisse, 11 Dateien


Neuere Versionen des Zend-Frameworks führen Zend_Application und Bootstrap ein. Zend_Application bietet einen Bootstrap aus wiederverwendbaren Ressourcen, generischen und modularen Bootstrap-Klassen und Abhängigkeitsprüfungen. Es ist außerdem dafür verantwortlich, standardmäßig PHP-Umgebungsvariablen und automatische Ladefunktionen festzulegen.

默认新建项目后,会给出如下的几个文件:

1.项目的Bootstrap

first_web/
├── application
│ ├── Bootstrap.php

具体代码如下:

<?php
class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
{
}
Nach dem Login kopieren

2.配置文件

│ ├── configs
│ │ └── application.ini

具体代码如下:

[production]
phpSettings.display_startup_errors = 0
phpSettings.display_errors = 0
includePaths.library = APPLICATION_PATH "/../library"
bootstrap.path = APPLICATION_PATH "/Bootstrap.php"
bootstrap.class = "Bootstrap"
appnamespace = "Application"
resources.frontController.controllerDirectory = APPLICATION_PATH "/controllers"
resources.frontController.params.displayExceptions = 0
[staging : production]
[testing : production]
phpSettings.display_startup_errors = 1
phpSettings.display_errors = 1
[development : production]
phpSettings.display_startup_errors = 1
phpSettings.display_errors = 1
resources.frontController.params.displayExceptions = 1
Nach dem Login kopieren

3.项目入口文件

├── public
│ └── index.php

<?php
// Define path to application directory
defined(&#39;APPLICATION_PATH&#39;)
  || define(&#39;APPLICATION_PATH&#39;, realpath(dirname(__FILE__) . &#39;/../application&#39;));
// Define application environment
defined(&#39;APPLICATION_ENV&#39;)
  || define(&#39;APPLICATION_ENV&#39;, (getenv(&#39;APPLICATION_ENV&#39;) ? getenv(&#39;APPLICATION_ENV&#39;) : &#39;production&#39;));
// Ensure library/ is on include_path
set_include_path(implode(PATH_SEPARATOR, array(
  realpath(APPLICATION_PATH . &#39;/../library&#39;),
  get_include_path(),
)));
/** Zend_Application */
require_once &#39;Zend/Application.php&#39;;
// Create application, bootstrap, and run
$application = new Zend_Application(
  APPLICATION_ENV,
  APPLICATION_PATH . &#39;/configs/application.ini&#39;
);
$application->bootstrap()
      ->run();
Nach dem Login kopieren

以上代码就是基本的使用Zend_Application方式,完成了环境变量的初始化,加载配置文件,初始化环境,加载模块,完成web应用程序的引导功能。

资源插件

资源插件只需要实现Zend_Application_Resource_Resource,或者,更简单的是,继承Zend_Application_Resource_ResourceAbstract。接口如下:

interface Zend_Application_Resource_Resource
{
  public function __construct($options = null);
  public function setBootstrap(
    Zend_Application_Bootstrap_Bootstrapper $bootstrap
  );
  public function getBootstrap();
  public function setOptions(array $options);
  public function getOptions();
  public function init();
}
Nach dem Login kopieren

例如

class My_Resource_View extends Zend_Application_Resource_ResourceAbstract
{
  protected $_view;
  public function init()
  {
    // Return view so bootstrap will store it in the registry
    return $this->getView();
  }
  public function getView()
  {
    if (null === $this->_view) {
      $options = $this->getOptions();
      $title  = &#39;&#39;;
      if (array_key_exists(&#39;title&#39;, $options)) {
        $title = $options[&#39;title&#39;];
        unset($options[&#39;title&#39;]);
      }
      $view = new Zend_View($options);
      $view->doctype(&#39;XHTML1_STRICT&#39;);
      $view->headTitle($title);
      $view->headLink()->appendStylesheet(&#39;/css/site.css&#39;);
      $view->headScript()->appendfile(&#39;/js/analytics.js&#39;);
      $viewRenderer =
        Zend_Controller_Action_HelperBroker::getStaticHelper(
          &#39;ViewRenderer&#39;
        );
      $viewRenderer->setView($view);
      $this->_view = $view;
    }
    return $this->_view;
  }
}
Nach dem Login kopieren

加载使用资源插件

我了提供资源的重用性,可以将资源方法定义为资源插件。。

为了让bootstrap能够识别资源插件,定义资源插件时,需要实现Zend_Application_Bootstrap_ResourceBootstrapper. 接口定义了查找插件,注册插件和加载插件的api:

interface Zend_Application_Bootstrap_ResourceBootstrapper
{
  public function registerPluginResource($resource, $options = null);
  public function unregisterPluginResource($resource);
  public function hasPluginResource($resource);
  public function getPluginResource($resource);
  public function getPluginResources();
  public function getPluginResourceNames();
  public function setPluginLoader(Zend_Loader_PluginLoader_Interface $loader);
  public function getPluginLoader();
}
Nach dem Login kopieren

采用资源插件,不仅可以让资源可以重复利用,同时让bootstrap更简洁,如果要修改,新增资源也无需修改你的bootstrap。

通过实现Zend_Application_Bootstrap_BootstrapAbstract (被 Zend_Application_Bootstrap_Bootstrap 继承) ,才可以使用定义的资源插件

通过将指定的选项传递到application object and/or bootstrap,来注册使用资源插件。这些选项可能会从一个配置文件,或通过手动指定。规则是选项必须是键值对,键代表资源名称。资源名称,是资源插件类的类前缀。例如,Zend框架自带的资源类前缀“Zend_Application_Resource_”;任何以下,这都是资源的名称。例如,

$application = new Zend_Application(APPLICATION_ENV, array(
  &#39;resources&#39; => array(
    &#39;FrontController&#39; => array(
      &#39;controllerDirectory&#39; => APPLICATION_PATH . &#39;/controllers&#39;,
    ),
  ),
));
Nach dem Login kopieren

"FrontController"资源是个特例。他的选项比较特殊。

无论是使用自己的写的资源插件还是使用第三方的资源插件。你必须保证bootstrap能找到他们,bootstrap 内部通过 Zend_Loader_PluginLoader可以让我们只需要指定资源插件的类前缀,值为资源类的类路径便可以轻松注册资源插件。

例如,如果编写的资源插件存放在APPLICATION_PATH/resources/ 下,类前缀为My_Resource. 可以使用如下方法注册加载:

$application = new Zend_Application(APPLICATION_ENV, array(
  &#39;pluginPaths&#39; => array(
    &#39;My_Resource&#39; => APPLICATION_PATH . &#39;/resources/&#39;,
  ),
  &#39;resources&#39; => array(
    &#39;FrontController&#39; => array(
      &#39;controllerDirectory&#39; => APPLICATION_PATH . &#39;/controllers&#39;,
    ),
  ),
));
Nach dem Login kopieren

在应用程序中比可以使用指定目录下的资源。

和资源方法类似,通过使用 the bootstrap() 方法可以加载资源插件。加载单一,多个,全部的资源插件的配置方式也类似.

例如:

// Execute one:
$bootstrap->bootstrap('FrontController');
// Execute several:
$bootstrap->bootstrap(array('FrontController', 'Foo'));
// Execute all resource methods and plugins:
$bootstrap->bootstrap();
Nach dem Login kopieren

资源注册表

为了避免资源的重复注册,导致不必要的浪费Zend_Application_Bootstrap_BootstrapAbstract 提供了一个本地注册表对象存储这些资源对象.当你想要存放一个资源的时候,只需要在方法中返回这个资源即可。

为了灵活性,注册表是作为一个内部“容器”存在的。只要是对象都可以存入到容器中。资源名称对应为容器的属性。默认情况下,可以通过Zend_Registry获取实例使用,也可以自定义其他对象。 setContainer() and getContainer() 方法可用于操纵容器本身。getResource($resource) 可用于获取一个指定资源。hasResource($resource) 可以检查资源是否已经注册存在

例如,注册一个view资源:

class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
{
  protected function _initView()
  {
    $view = new Zend_View();
    // more initialization...
    return $view;
  }
}
Nach dem Login kopieren

资源的相关操作:

// Using the has/getResource() pair:
if ($bootstrap->hasResource(&#39;view&#39;)) {
  $view = $bootstrap->getResource(&#39;view&#39;);
}
// Via the container:
$container = $bootstrap->getContainer();
if (isset($container->view)) {
  $view = $container->view;
}
Nach dem Login kopieren

请注意:注册表容器是不是全局的。这意味着你需要通过访问的bootstrap来获取资源。 Zend_Application_Bootstrap_Bootstrap提供了 run() , 执行了 run() 之后,它会注册为前端控制器参数的“bootstrap”,通过他可以获取路由器,分发器,插件和动作控制器。

具体使用方法:

class FooController extends Zend_Controller_Action
{
  public function init()
  {
    $bootstrap = $this->getInvokeArg(&#39;bootstrap&#39;);
    $view = $bootstrap->getResource(&#39;view&#39;);
    // ...
  }
}
Nach dem Login kopieren

为了防止重复注册加载资源方法和插件或一些资源可能依赖于其他资源。为了解决这两个问题,Zend_Application_Bootstrap_BootstrapAbstract提供了一个简单的依赖性跟踪机制。

如前所述,所有的资源 - 无论是方法或插件 - 是通过 bootstrap($resource)加载运行的,其中 $resource是资源的名称,或者资源名称数组,或者为空,为空表示加载运行所有资源。

class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
{
  protected function _initRequest()
  {
    // Ensure the front controller is initialized
    $this->bootstrap(&#39;FrontController&#39;);
    // Retrieve the front controller from the bootstrap registry
    $front = $this->getResource(&#39;FrontController&#39;);
    $request = new Zend_Controller_Request_Http();
    $request->setBaseUrl(&#39;/foo&#39;);
    $front->setRequest($request);
    // Ensure the request is stored in the bootstrap registry
    return $request;
  }
}
Nach dem Login kopieren

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

Zend Framework中Zend_View组件的用法解析

Zend Framework动作助手的用法解析

Zend Nutzungsanalyse des Framework-Validators Zend_Validate

Das obige ist der detaillierte Inhalt vonAnwendungs- und Bootstrap-Nutzung im Zend Framework. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!