Zend_Loader.xml 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. <!-- EN-Revision: 12819 -->
  2. <sect1 id="zend.loader.load">
  3. <title>Charger les fichiers et les classes dynamiquement</title>
  4. <para>La classe <classname>Zend_Loader</classname> inclut des méthodes afin de vous aider à charger des fichiers
  5. dynamiquement.</para>
  6. <tip>
  7. <title>Zend_Loader contre require_once()</title>
  8. <para>Les méthodes <classname>Zend_Loader</classname> sont les meilleures à utiliser si le nom de fichier que vous devez
  9. charger est variable. Par exemple, s'il est basé sur un paramètre de la saisie de l'utilisateur ou un argument
  10. de méthode. Si vous chargez un fichier ou une classe dont le nom est constant, il n'y a aucun avantage à
  11. l'utilisation de <classname>Zend_Loader</classname> sur l'utilisation de fonctions de PHP traditionnelles comme <ulink
  12. url="http://php.net/require_once"><code>require_once()</code></ulink>.</para>
  13. </tip>
  14. <sect2 id="zend.loader.load.file">
  15. <title>Charger des fichiers</title>
  16. <para>La méthode statique <classname>Zend_Loader::loadFile()</classname> charge un fichier PHP, qui peut contenir du code
  17. PHP arbitraire. Cette méthode enveloppe la fonction PHP <ulink
  18. url="http://php.net/include"><code>include()</code></ulink>, et retournera le booléen <code>false</code>
  19. si le fichier n'existe pas.</para>
  20. <example id="zend.loader.file.example">
  21. <title>Exemple d'utilisation de la méthode loadFile()</title>
  22. <programlisting role="php"><![CDATA[
  23. Zend_Loader::loadFile($filename, $dirs=null, $once=false);
  24. ]]></programlisting>
  25. </example>
  26. <para>L'argument <code>$filename</code> définit le nom du fichier à charger, et il ne doit contenir aucune
  27. information concernant son chemin d'accès. Une vérification de sécurité est effectuée sur
  28. <code>$filename</code>. Le fichier <code>$filename</code> ne peut contenir que des caractères alphanumérique,
  29. des tirets ("-"), des tirets-bas ("_") ou des points ("."). Aucune de ces restrictions ne s'applique à
  30. l'argument <code>$dirs</code>.</para>
  31. <para>L'argument <code>$dirs</code> définit les dossiers où rechercher le fichier. Si <code>NULL</code>, la
  32. recherche s'effectuera uniquement dans les dossiers définis par la variable <code>include_path</code>. Si c'est
  33. une chaîne ou un tableau, le ou les répertoires spécifiés seront scannés, ainsi que les dossiers définis par la
  34. variable <code>include_path</code>.</para>
  35. <para>L'argument <code>$once</code> est un booléen. Si <code>true</code>, <classname>Zend_Loader::loadFile()</classname>
  36. utilise la fonction PHP <ulink url="http://php.net/include"><code>include_once()</code></ulink> pour charger le
  37. fichier sinon la fonction PHP <ulink url="http://php.net/include"><code>include()</code></ulink> est
  38. utilisée.</para>
  39. </sect2>
  40. <sect2 id="zend.loader.load.class">
  41. <title>Charger des classes</title>
  42. <para>La méthode statique <classname>Zend_Loader::loadClass($class, $dirs)</classname> charge un fichier PHP et vérifie
  43. l'existence de la classe.</para>
  44. <example id="zend.loader.load.class.example">
  45. <title>Exemple d'utilisation de la méthode loadClass()</title>
  46. <programlisting role="php"><![CDATA[
  47. Zend_Loader::loadClass('Container_Tree',
  48. array(
  49. '/home/production/mylib',
  50. '/home/production/myapp'
  51. )
  52. );
  53. ]]></programlisting>
  54. </example>
  55. <para>La chaîne spécifiant la classe est convertie en chemin relatif en remplaçant les tirets bas ("_") par le
  56. séparateur de dossier puis en ajoutant le bloc ".php". Dans l'exemple ci-dessus, "Container_Tree" devient
  57. "Container/Tree.php".</para>
  58. <para>Si <code>$dirs</code> est une chaîne ou un tableau, <classname>Zend_Loader::loadClass()</classname> va chercher dans
  59. les dossiers suivant l'ordre donné. Le premier fichier trouvé est chargé. Si le fichier n'existe pas dans les
  60. dossiers spécifiés <code>$dirs</code>, alors la recherche est effectuée dans <code>include_path</code> du
  61. PHP.</para>
  62. <para>Si le fichier n'est pas trouvé ou que la classe n'existe pas après le chargement,
  63. <classname>Zend_Loader::loadClass()</classname> lèvera une exception <classname>Zend_Exception</classname></para>
  64. <para><classname>Zend_Loader::loadFile()</classname> est utilisé pour le chargement, donc le nom de la classe ne peut
  65. contenir que des caractères alphanumériques et les caractères tiret ("-"), tiret bas ("_"), et point
  66. (".").</para>
  67. </sect2>
  68. <sect2 id="zend.loader.load.isreadable">
  69. <title>Tester si un fichier est lisible</title>
  70. <para>La méthode statique <classname>Zend_Loader::isReadable($pathname)</classname> retourne <code>true</code> si le
  71. fichier existe dans le dossier spécifié et qu'il est lisible, sinon <code>false</code>.</para>
  72. <example id="zend.loader.load.isreadable.example">
  73. <title>Exemple d'utilisation de la méthode isReadable()</title>
  74. <programlisting role="php"><![CDATA[
  75. if (Zend_Loader::isReadable($filename)) {
  76. // puis manipulation avec $filename
  77. }
  78. ]]></programlisting>
  79. </example>
  80. <para>L'argument <code>$filename</code> spécifie le nom du fichier à vérifier. Il peut contenir des informations
  81. concernant le chemin d'accès. Cette méthode enveloppe la fonction PHP <ulink
  82. url="http://php.net/is_readable"><code>is_readable()</code></ulink>. La fonction PHP ne recherche pas le fichier
  83. spécifié dans les répertoires de l'<code>include_path</code>, contrairement à
  84. <classname>Zend_Loader::isReadable()</classname>.</para>
  85. </sect2>
  86. <sect2 id="zend.loader.load.autoload">
  87. <title>Utiliser l'autoloader</title>
  88. <para>La classe Zend_Loader contient une méthode <classname>Zend_Loader::autoload()</classname> que vous pouvez inscrire
  89. dans le PHP SPL autoloader. Par commodité, <classname>Zend_Loader</classname> fournit la fonction
  90. <code>registerAutoload()</code> qui enregistre automatiquement sa méthode <code>autoload()</code>. Si
  91. l'extension <code>spl_autoload</code> n'est pas présente dans l'environnement PHP, alors la méthode
  92. <code>registerAutoload()</code> lèvera une <classname>Zend_Exception</classname>.</para>
  93. <example id="zend.loader.load.autoload.example">
  94. <title>Exemple d'inscription de la méthode de callback autoloader</title>
  95. <programlisting role="php"><![CDATA[
  96. Zend_Loader::registerAutoload();
  97. ]]></programlisting>
  98. </example>
  99. <para>Après avoir inscrit le callback vers l'autoload de Zend Framework, vous pouvez appeler une classe de Zend
  100. Framework sans l'avoir explicitement chargé auparavant. La méthode autoload utilise automatiquement
  101. <classname>Zend_Loader::loadClass()</classname> quand vous appelez une classe.</para>
  102. <para>Si vous avez étendu la classe <classname>Zend_Loader</classname>, vous pouvez passer un argument optionnel à
  103. <code>registerAutoload()</code>, pour spécifier la classe de laquelle vous souhaitez enregistrer la méthode
  104. <code>autoload()</code>.</para>
  105. <example id="zend.loader.load.autoload.example-extended">
  106. <title>Exemple d'inscription de la méthode de callback autoloader d'une classe étendue</title>
  107. <para>A cause de la sémantique de référencement des fonctions statiques en PHP, vous devez implémenter le
  108. code pour les méthodes <code>loadClass()</code> et <code>autoload()</code>, et la méthode
  109. <code>autoload()</code> doit appeler <code>self::loadClass()</code>. Si votre méthode
  110. <code>autoload()</code> délégue à son parent l'appel <code>self::loadClass()</code>, alors cela appellerait
  111. la méthode de même nom dans la classe parente et non dans la sous-classe.</para>
  112. <programlisting role="php"><![CDATA[
  113. class Mon_Chargeur extends Zend_Loader
  114. {
  115. public static function loadClass($class, $dirs = null)
  116. {
  117. parent::loadClass($class, $dirs);
  118. }
  119. public static function autoload($class)
  120. {
  121. try {
  122. self::loadClass($class);
  123. return $class;
  124. } catch (Exception $e) {
  125. return false;
  126. }
  127. }}
  128. Zend_Loader::registerAutoload('Mon_Chargeur');
  129. ]]></programlisting>
  130. </example>
  131. <para>Vous pouvez effacer un callback d'autoload. <code>registerAutoload()</code> a un paramètre optionnel, qui
  132. est réglé à <code>true</code> par défaut. S'il vaut <code>false</code>, le callback de l'autoload est alors
  133. effacé de la pile des autoload SPL.</para>
  134. </sect2>
  135. </sect1>