<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/install.windows.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'fr',
  ),
  'this' => 
  array (
    0 => 'install.windows.commandline.php',
    1 => 'Ex&eacute;cution de PHP en ligne de commande sur les syst&egrave;mes Windows',
    2 => 'Ex&eacute;cution de PHP en ligne de commande sur les syst&egrave;mes Windows',
  ),
  'up' => 
  array (
    0 => 'install.windows.php',
    1 => 'Installation sur les syst&egrave;mes Windows',
  ),
  'prev' => 
  array (
    0 => 'install.windows.building.php',
    1 => 'Construire &agrave; partir des sources',
  ),
  'next' => 
  array (
    0 => 'install.cloud.php',
    1 => 'Installation sur des plateformes de Cloud Computing',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'fr',
    'path' => 'install/windows/commandline.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="install.windows.commandline" class="sect1">
 <h2 class="title">Exécution de PHP en ligne de commande sur les systèmes Windows</h2>
 <p class="para">
  Cette section contient des notes et des astuces spécifiques à l&#039;exécution de PHP
  en ligne de commande sur Windows.
 </p>
 <blockquote class="note"><p><strong class="note">Note</strong>: 
  <p class="para">
   Il convient de lire les <a href="install.windows.manual.php" class="link">étapes
   d&#039;installation manuelle</a> en premier !
  </p>
 </p></blockquote>
 <p class="para">
  Avoir PHP qui s&#039;exécute à partir de la ligne de commande peut être effectué sans
  apporter de modifications à Windows.
  <div class="example-contents screen">
<div class="cdata"><pre>
C:\php\php.exe -f &quot;C:\PHP Scripts\script.php&quot; -- -arg1 -arg2 -arg3
</pre></div>
  </div>
 </p>

 <p class="para">
  Mais il y a quelques étapes faciles à suivre pour simplifier cela.
  Certaines de ces étapes auraient déjà dû être prises, mais sont répétées ici
  pour pouvoir fournir une séquence étape par étape complète.

  <ul class="itemizedlist">
   <blockquote class="note"><p><strong class="note">Note</strong>: 
    <p class="para">
     Les deux variables système pré-existantes <var class="envar">PATH</var> et <var class="envar">PATHEXT</var> sont
     importantes dans Windows,
     et il faut faire attention à ne pas les écraser,
     seulement les ajouter.
    </p>
   </p></blockquote>

   <li class="listitem">
    <p class="para">
     Ajouter l&#039;emplacement de l&#039;exécutable PHP (<var class="filename">php.exe</var>,
     <var class="filename">php-win.exe</var> ou <var class="filename">php-cli.exe</var>
     selon la version de PHP et les préférences d&#039;affichage) à la variable
     d&#039;environnement <var class="envar">PATH</var>. Lire la section sur comment ajouter le
     répertoire PHP approprié à la variable d&#039;environnement <var class="envar">PATH</var> dans la
     <a href="faq.installation.php#faq.installation.addtopath" class="link">entrée FAQ correspondante</a>.
    </p>
   </li>

   <li class="listitem">
    <p class="para">
     Ajouter l&#039;extension <code class="literal">.PHP</code>
     à la variable d&#039;environnement <var class="varname">PATHEXT</var>. Ceci peut être fait
     en même temps que l&#039;ajout de la variable d&#039;environnement <var class="envar">PATH</var>.
     Suivre les mêmes étapes que décrites dans la <a href="faq.installation.php#faq.installation.addtopath" class="link">FAQ</a> mais modifier la variable
     d&#039;environnement <var class="varname">PATHEXT</var> plutôt que la variable
     d&#039;environnement <var class="envar">PATH</var>.
     <blockquote class="note"><p><strong class="note">Note</strong>: 
      <p class="para">
       La position dans laquelle le <code class="literal">.PHP</code> est placé déterminera
       quel script ou programme est exécuté lorsqu&#039;il y a des noms de fichiers
       correspondants. Par exemple, placer <code class="literal">.PHP</code> avant
       <code class="literal">.BAT</code> fera exécuter le script, plutôt que le 
       fichier batch, s&#039;il y a un fichier batch avec le même nom.
      </p>
     </p></blockquote>
    </p>
   </li>

   <li class="listitem">
    <p class="para">
     Associer l&#039;extension <code class="literal">.PHP</code> avec un type de fichier. Ceci
     est fait en exécutant la commande suivante :
     <div class="example-contents screen">
<div class="cdata"><pre>
assoc .php=phpfile
</pre></div>     
     </div>
    </p>
   </li>

   <li class="listitem">
    <p class="para">
     Associer le type de fichier <code class="literal">phpfile</code> avec l&#039;exécutable PHP
     approprié. Ceci est fait en exécutant la commande suivante :    
     <div class="example-contents screen">
<div class="cdata"><pre>
ftype phpfile=&quot;C:\php\php.exe&quot; -f &quot;%1&quot; -- %~2
</pre></div>     
     </div>
    </p>
   </li>

  </ul>
 </p>

 <p class="para">
  En suivant ces étapes, les scripts PHP pourront être exécutés depuis n&#039;importe quel
  répertoire sans avoir besoin de taper l&#039;exécutable PHP ou l&#039;extension
  <code class="literal">.PHP</code> et tous les paramètres seront fournis au script pour traitement.
 </p>

 <p class="para">
  L&#039;exemple ci-dessous détaille certains des changements de registre qui peuvent être faits manuellement.
  <div class="example" id="example-1">
   <p><strong>Exemple #1 Changements de registre</strong></p>
   <div class="example-contents screen">
<div class="cdata"><pre>
Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\.php]
@=&quot;phpfile&quot;
&quot;Content Type&quot;=&quot;application/php&quot;

[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\phpfile]
@=&quot;PHP Script&quot;
&quot;EditFlags&quot;=dword:00000000
&quot;BrowserFlags&quot;=dword:00000008
&quot;AlwaysShowExt&quot;=&quot;&quot;

[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\phpfile\DefaultIcon]
@=&quot;C:\\php\\php-win.exe,0&quot;

[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\phpfile\shell]
@=&quot;Open&quot;

[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\phpfile\shell\Open]
@=&quot;&amp;Open&quot;

[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\phpfile\shell\Open\command]
@=&quot;\&quot;C:\\php\\php.exe\&quot; -f \&quot;%1\&quot; -- %~2&quot;
</pre></div>
   </div>
  </div>
 </p>

 <p class="para">
  Avec ces changements, la même commande peut être écrite comme suit :
  <div class="example-contents screen">
<div class="cdata"><pre>
&quot;C:\PHP Scripts\script&quot; -arg1 -arg2 -arg3
</pre></div>
  </div>
  ou, si le chemin <code class="literal">&quot;C:\PHP Scripts&quot;</code> est dans la 
  variable d&#039;environnement <var class="envar">PATH</var> :
  <div class="example-contents screen">
<div class="cdata"><pre>
script -arg1 -arg2 -arg3
</pre></div>
  </div>
 </p>

 <blockquote class="note"><p><strong class="note">Note</strong>: 
  <p class="para">
   Il y a un petit problème si l&#039;on souhaite utiliser cette technique et
   utiliser les scripts PHP comme filtre en ligne de commande, comme l&#039;exemple ci-dessous :
   <div class="example-contents screen">
<div class="cdata"><pre>
dir | &quot;C:\PHP Scripts\script&quot; -arg1 -arg2 -arg3
</pre></div>
   </div>
   ou
   <div class="example-contents screen">
<div class="cdata"><pre>
dir | script -arg1 -arg2 -arg3
</pre></div>
   </div>
   Le script peut simplement se bloquer et rien ne s&#039;affiche.
   Pour que cela fonctionne, un autre changement de registre doit être effectué :
   <div class="example-contents screen">
<div class="cdata"><pre>
Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\policies\Explorer]
&quot;InheritConsoleHandles&quot;=dword:00000001
</pre></div>
   </div>
   Plus d&#039;informations sur ce problème peuvent être trouvées dans cet <a href="http://support.microsoft.com/default.aspx?scid=kb;en-us;321788" class="link external">&raquo;&nbsp;article de la base de connaissances Microsoft : 321788</a>.
   À partir de Windows 10, ce paramètre semble être inversé, rendant l&#039;installation par défaut de
   Windows 10 supportant automatiquement les gestionnaires de console hérités. Ce <a href="https://social.msdn.microsoft.com/Forums/en-US/f19d740d-21c8-4dc2-a9ab-d5c0527e932b/nasty-file-association-regression-bug-in-windows-10-console?forum=windowssdk" class="link external">&raquo;&nbsp;
   post du forum Microsoft</a> fournit l&#039;explication.
  </p>
 </p></blockquote>
</div><?php manual_footer($setup); ?>