ob_list_handlers
<<<
ob_start output_add_rewrite_var
>>>

6.28 Bufferisation de sortie
6 Référence des fonctions
 Manuel PHP

Introduction
Pré-requis
Installation
Configuration à l'exécution
Types de ressources
Constantes pré-définies
Exemples
Voir aussi
flush
ob_clean
ob_end_clean
ob_end_flush
ob_flush
ob_get_clean
ob_get_contents
ob_get_flush
ob_get_length
ob_get_level
ob_get_status
ob_gzhandler
ob_implicit_flush
ob_list_handlers
->ob_start
output_add_rewrite_var
output_reset_rewrite_vars

6.28.23 ob_start()Enclenche la bufferisation de sortie

[ Exemples avec ob_start ]   PHP 4, PHP 5

bool  ob_start ( callback   output_callback , int   chunk_size , bool   erase )

ob_start démarre la bufferisation de sortie. Tant qu'elle est enclenchée, aucune donnée, hormis les en-têtes, n'est envoyée au navigateur, mais temporairement mise en buffer.

Le contenu de ce buffer peut être copié dans une chaîne avec la fonction ob_get_contents . Pour afficher le contenu de ce buffer, utilisez ob_end_flush . = Au contraire, ob_end_clean effacera le contenu de ce buffer.

Une fonction optionnelle de callback peut être spécifiée en troisième argument. ob_start prend une chaîne comme paramètre, et retourne une chaîne. Elle sera appelée par ob_end_flush ou lorsque le buffer sera envoyé au navigateur à la fin du script et recevra le contenu du buffer de sortie. Lorsque la fonction output_callback est appelée, elle doit retourner un nouveau contenu pour le buffer de sortie : celui-ci sera envoyé au navigateur. Si output_callback n'est pas une fonction accessible, la fonction retournera FALSE . Si la fonction de callback a deux paramètres, le second est composé du champ bits constitué par PHP_OUTPUT_HANDLER_START , PHP_OUTPUT_HANDLER_CONT et PHP_OUTPUT_HANDLER_END .

Note

En PHP 4.0.4, ob_gzhandler a été introduite pour faciliter l'envoi de fichiers compressés avec gz aux navigateurs web qui supportent les pages compressées. ob_gzhandler détermine le type d'encodage accepté par un navigateur, et retourne le contenu le plus adéquat.

Note

Avant PHP 4.3.2, cette fonction ne retournait pas FALSE dans le cas où output_callback ne pouvait être exécutée.

Attention

Quelques serveurs web (e.g. Apache) modifient le dossier de travail d'un script lorsqu'il appelle une fonction de callback. Vous pouvez revenir à un comportement normal en ajoutant chdir(dirname($_SERVER['SCRIPT_FILENAME'])) dans votre fonction de callback.

Si le paramètre optionnel chunk_size est passé, la fonction de callback est appelée à chaque nouvelle ligne après chunk_size octets d'affichage. Le paramètre output_callback peut être outrepassé en lui affectant la valeur NULL .

Si le paramètre optionnel erase est défini à FALSE , le buffer ne sera pas effacé tant que le script ne sera pas terminé (depuis PHP 4.3.0).

Les buffers de sortie sont gérés par pile, c'est-à-dire que vous pouvez appeler plusieurs fois ob_start simultanément. Assurez-vous que vous appelez ob_end_flush suffisamment souvent. Si plusieurs fonctions de callback sont actives, les contenus seront filtrés séquentiellement, dans l'ordre d'emboîtement.

ob_end_clean , ob_end_flush , ob_clean , ob_flush et ob_start ne doivent pas être appelés depuis une fonction de callback. Si vous les appelez depuis une fonction de callback, le comportement ne sera pas défini. Si vous voulez effacer le contenu du buffer, retournez "" (une chaîne vide) comme fonction de callback. Vous ne pourrez jamais appeler les fonctions utilisant la fonction de bufferisation de sortie comme print_r($expression, true) ou highlight_file($filename, true) depuis une fonction de coolback.

Exemple de gestion de sortie avec fonction utilisateur

<?php

function callback($buffer)
{
    
// remplace toutes les pommes par des carottes
    
return (ereg_replace("pommes de terre", "carottes", $buffer));
}

ob_start("callback");

?>

<html>
<body>
<p>C'est comme comparer des carottes et des pommes de terre.</p>
</body>
</html>

<?php

ob_end_flush
();

?>

Voir aussi ob_get_contents , ob_end_flush , ob_end_clean , ob_implicit_flush , ob_gzhandler , ob_iconv_handler , mb_output_handler et ob_tidyhandler .

<< ob_start >>
ob_list_handlers Bufferisation de sortie output_add_rewrite_var