Utilisation de la réécriture de sortie

Depuis PHP 7.1.0, output_add_rewrite_var(), output_reset_rewrite_vars() utilise un tampon de sortie dédié. c'est-à-dire qu'il n'utilise pas de tampon de sortie trans sid.

Exemple #1 Exemple de réécriture de la sortie

<?php
// Ce code fonctionne avec PHP 7.1.0, 7.0.10, 5.6.25 et suppérieur.

// HTTP_HOST est l'hôte cible par défaut. Définir manuellement pour que l'exemple de code fonctionne.
$_SERVER['HTTP_HOST'] = 'php.net';

// La réécriture de la sortie ne peut réécrire que les form. Ajouter a=href.
// LEs balises peuvent être spécifiées tag_name=url_attr, e.g. img=src,iframe=src
// Aucun espace autorisé entres les paramètres.
// La balise form est une balise spéciale qui ajoute un champ cachée.
ini_set('url_rewriter.tags','a=href,form=');
var_dump(ini_get('url_rewriter.tags'));

// This is added to URL and form
output_add_rewrite_var('test''value');
?>
<a href="//php.net/index.php?bug=1234">bug1234</a>
<form action="https://php.net/?bug=1234&edit=1" action="post">
 <input type="text" name="title" />
</form>

L'exemple ci-dessus va afficher :

<a href="//php.net/?bug=1234&test=value">bug1234</a>
<form action="https://php.net/?bug=1234&edit=1" method="post"><input type="hidden" name="test" value="value" />
 <input type="text" name="title" />
</form>

Depuis PHP 7.1.0, les fonctions de réécriture de sortie ont leurs propres paramètres INI, url_rewriter.tags et url_rewriter.hosts.