Maison >développement back-end >tutoriel php >Analyse du tampon de sortie de la classe PHP Flush

Analyse du tampon de sortie de la classe PHP Flush

高洛峰
高洛峰original
2016-12-22 16:30:14903parcourir

for ($i=10; $i>0; $i--)
{
echo $i;
flush(); 1);
}
?>
Selon le manuel PHP
Cette fonction envoie toute la sortie du programme jusqu'à présent au navigateur de l'utilisateur.
Le code ci-dessus devrait afficher $i toutes les secondes. Mais ce n’est pas forcément le cas en pratique. Il est possible qu'après 10 secondes d'attente, toutes les sorties soient présentées en même temps.
D'accord, changeons ce code en
ob_end_clean();//Modify part
for ($i=10; $i>0; $i --)
{
echo $i;
flush();
sleep(1);
}
?> Hé, j'ai ajouté cette phrase ob_end_clean( );, c'est en fait OK . En fait, c'est également OK si nous remplaçons ob_end_clean() par ob_end_flush().
Je vais le changer à nouveau.
for ($i=10; $i>0; $i--)
{
echo $i;
ob_flush();//Modifier la partie
flush();
sleep(1);
}
?> Exécutez-le, trouvez-vous que $i est également affiché toutes les secondes ? Pourquoi est-ce ?
Ne vous inquiétez pas, jetons un œil à php.ini.
Ouvrez php.ini, recherchez output_buffering, nous verrons un paramètre comme celui-ci output_buffering = 4096. Tout comme son nom output_buffering, la fonction de ce paramètre est de mettre en mémoire tampon la sortie. La taille du tampon est de 4096 octets.
Dans notre premier morceau de code, la raison pour laquelle la sortie n'est pas celle attendue est précisément parce que ce output_buffering met la sortie en mémoire tampon. Le tout mis en mémoire tampon. La sortie ne sera pas envoyée avant que 4096 octets ne soient atteints ou que le script ne se termine.
La fonction de ob_end_clean() et ob_end_flush() dans le deuxième morceau de code est de terminer la mise en mémoire tampon. De cette façon, il n'est pas nécessaire d'attendre qu'il y ait un tampon de 4096 octets avant d'être envoyé.
Dans le troisième morceau de code, ob_flush() est utilisé. Sa fonction est d'envoyer les données mises en mémoire tampon, mais il ne termine pas la mise en mémoire tampon, il doit donc être utilisé avant chaque flush().
Si nous ne voulons pas utiliser ob_end_clean(), ob_end_flush() et ob_flush(), nous devons définir output_buffering dans php.ini suffisamment petit, par exemple, défini sur 0. Il convient de noter que si vous envisagez d'utiliser ini_set("output_buffering","0") pour le définir dans un script, alors arrêtez, cette méthode ne fonctionnera pas. Parce qu'au début du script, les paramètres de mise en mémoire tampon ont été chargés, puis la mise en mémoire tampon démarre.
Peut-être vous demanderez-vous, puisque ob_flush() envoie les données mises en mémoire tampon, pourquoi avez-vous besoin d'utiliser flush() ??? Ne pouvez-vous pas simplement utiliser le code suivant ? ?
for ($i=10; $i>0; $i--)
{
echo $i;
ob_flush(
sleep(); 1);
}
?>
Veuillez noter la différence entre ob_flush() et flush(). La première consiste à libérer les données du tampon PHP, et la seconde consiste à envoyer les données qui ne sont pas dans le tampon ou qui ont été publiées au navigateur. Ainsi, lorsque le buffer existe, il faut utiliser ob_flush() et flush() en même temps.
Flush() est-il indispensable ici ? Non, nous avons une autre méthode pour que lorsque les données sont sorties, elles soient immédiatement envoyées au navigateur. Les deux morceaux de code suivants n'ont pas besoin d'utiliser flush(). (Lorsque vous définissez output_buffering sur 0, vous n'avez même pas besoin de ob_flush() et ob_end_clean())
ob_implicit_flush(true)
for ($i=10; $ i> 0; $i--)
{
echo $i;
ob_flush();
sleep(1)
?>
ob_end_clean();
ob_implicit_flush(true);
for ($i=10; $i>0; $i--)
{
echo $i; (1);
}
?>
Veuillez noter ob_implicit_flush(true) ci-dessus. Cette fonction force l'envoi immédiat de la sortie au navigateur chaque fois qu'il y a une sortie. De cette façon, il n'est pas nécessaire d'utiliser flush() pour l'envoyer au navigateur après chaque sortie (écho).
La plainte ci-dessus peut ne pas être vraie dans certains navigateurs. Parce que les navigateurs ont aussi leurs propres règles. J'ai utilisé Firefox1.5, IE6, opera8.5 pour tester. Parmi eux, Opera ne peut pas sortir normalement car il a une règle selon laquelle s'il ne rencontre pas de balise HTML, il ne sortira jamais à moins que le script ne se termine. FireFox et IE sont relativement normaux.
Enfin, un morceau de code très intéressant est joint, écrit par PuTTYshell. Dans un cycle de script, chaque sortie écrasera la sortie précédente.
Le code suivant est uniquement disponible sous Firefox. Les autres navigateurs ne prennent pas en charge le Content-Type de multipart/x-mixed-replace
header('Content-type: multipart/x. - Mixed-replace;boundary=endofsection');
print "n--endofsectionn";
$pmt = array("-", "\", "|", "/" ); for ( $i = 0; $i <10; $i ){
sleep(1);
print "Type de contenu : text/plainnn"
print "Part $it".$pmt[$i % 4];
print "--endofsectionn"
ob_flush(); -type : text/plainnn";
imprimer "La fin";
imprimer "--endofsection--n";
?>



Pour plus d'articles liés à l'analyse du tampon de sortie de vidage PHP, veuillez faire attention au site Web PHP chinois !

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn