Analyse des Ausgabepuffers der PHP-Flush-Klasse
for ($i=10; $i>0; $i--)
{
echo $i;
sleep(); 1);
}
?>
Laut PHP-Handbuch
Diese Funktion sendet alle bisherigen Ausgaben des Programms an den Browser des Benutzers.
Der obige Code sollte jede Sekunde $i ausgeben. Dies ist jedoch in der Praxis nicht unbedingt der Fall. Es ist möglich, dass nach einer Wartezeit von 10 Sekunden alle Ausgaben gleichzeitig angezeigt werden.
Okay, ändern wir diesen Code in
ob_end_clean();//Modify part
for ($i=10; $i>0; $i --)
{
echo $i;
sleep(1);
?> . Tatsächlich ist es auch in Ordnung, wenn wir ob_end_clean() durch ob_end_flush() ersetzen.
Ich werde es wieder ändern.
for ($i=10; $i>0; $i--)
{
echo $i;
ob_flush();//Teil ändern
flush();
sleep(1);
}
Führen Sie es aus. Finden Sie, dass $i auch jede Sekunde ausgegeben wird? Warum ist das so?
Keine Sorge, werfen wir einen Blick auf php.ini.
Öffnen Sie php.ini und suchen Sie nach „output_buffering“. Wir sehen eine Einstellung wie diese: „output_buffering = 4096“. Genau wie der Name „output_buffering“ besteht die Funktion dieser Einstellung darin, die Ausgabe zu puffern.
In unserem ersten Codeteil ist der Grund, warum die Ausgabe nicht wie erwartet ist, genau darin, dass „output_buffering“ die Ausgabe puffert Alles gepuffert. Die Ausgabe wird erst gesendet, wenn 4096 Bytes erreicht sind oder das Skript endet.
Die Funktion von ob_end_clean() und ob_end_flush() im zweiten Codeteil besteht darin, die Pufferung zu beenden. Auf diese Weise muss vor dem Versenden nicht gewartet werden, bis ein Puffer von 4096 Byte vorhanden ist.
Im dritten Codeteil wird ob_flush() verwendet. Seine Funktion besteht darin, die gepufferten Daten zu senden, die Pufferung wird jedoch nicht beendet, sodass es vor jedem Flush() verwendet werden muss.
Wenn wir ob_end_clean(), ob_end_flush() und ob_flush() nicht verwenden möchten, müssen wir Output_buffering in php.ini klein genug einstellen, zum Beispiel auf 0 setzen. Es ist zu beachten, dass diese Methode nicht funktioniert, wenn Sie ini_set("output_buffering","0") verwenden möchten, um es in einem Skript festzulegen. Bitte stoppen Sie dies, da diese Methode nicht funktioniert. Denn zu Beginn des Skripts wurden die Pufferungseinstellungen geladen und dann beginnt die Pufferung.
Vielleicht fragen Sie sich, warum Sie „flush()“ verwenden müssen, da ob_flush() die gepufferten Daten sendet? ?
for ($i=10; $i>0; $i--)
{
echo $i;
ob_flush(
sleep(); 1);
}
?> Bitte beachten Sie den Unterschied zwischen ob_flush() undlush(). Ersteres besteht darin, Daten aus dem PHP-Puffer freizugeben, und letzteres besteht darin, Daten, die sich nicht im Puffer befinden oder freigegeben wurden, an den Browser zu senden. Wenn also der Puffer vorhanden ist, müssen wir ob_flush() und Flush() gleichzeitig verwenden.
Ist Flush() hier unverzichtbar? Nein, wir haben eine andere Methode, bei der Daten bei der Ausgabe sofort an den Browser gesendet werden. Die folgenden beiden Codeteile müssen Flush() nicht verwenden. (Wenn Sie „output_buffering“ auf 0 setzen, brauchen Sie nicht einmal ob_flush() und ob_end_clean())
ob_implicit_flush(true); for ($i=10; $ i> 0; $i--)
echo $i;
sleep(1);
<
ob_end_clean();
ob_implicit_flush(true);
for ($i=10; $i>0; $i--)
{
echo $i; (1);
}
?> Bitte beachten Sie ob_implicit_flush(true) oben. Diese Funktion erzwingt, dass die Ausgabe sofort an den Browser gesendet wird. Auf diese Weise ist es nicht erforderlich, Flush() zu verwenden, um es nach jeder Ausgabe (Echo) an den Browser zu senden.
Die obige Beschwerde trifft bei manchen Browsern möglicherweise nicht zu. Denn auch Browser haben ihre eigenen Regeln. Zum Testen habe ich Firefox 1.5, IE6 und Opera 8.5 verwendet. Unter anderem kann Opera nicht normal ausgeben, da es die Regel hat, dass es nie ausgegeben wird, wenn es nicht auf ein HTML-Tag stößt, es sei denn, das Skript wird beendet. Firefox und IE sind relativ normal.
Schließlich ist ein sehr interessanter Code angehängt, geschrieben von PuTTYshell. In einem Skriptzyklus überschreibt jede Ausgabe die vorherige Ausgabe.
Der folgende Code ist nur unter Firefox verfügbar. Andere Browser unterstützen den Content-Type von multipart/x-mixed-replace nicht - Mixed-replace;boundary=endofsection');
print "n--endofsectionn"
$pmt = array("-", "\", "|", "/" ); for ( $i = 0; $i <10; $i ++ ){
sleep(1);print „Part $it“.$pmt[$i % 4];
print „--endofsectionn“;
flush(); -type: text/plainnn";
print "The endn";
print "--endofsection--n";
?>
Weitere Artikel zur PHP-Flush-Ausgabepufferanalyse finden Sie auf der chinesischen PHP-Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Laravel vereinfacht die Behandlung von temporären Sitzungsdaten mithilfe seiner intuitiven Flash -Methoden. Dies ist perfekt zum Anzeigen von kurzen Nachrichten, Warnungen oder Benachrichtigungen in Ihrer Anwendung. Die Daten bestehen nur für die nachfolgende Anfrage standardmäßig: $ Anfrage-

Die PHP Client -URL -Erweiterung (CURL) ist ein leistungsstarkes Tool für Entwickler, das eine nahtlose Interaktion mit Remote -Servern und REST -APIs ermöglicht. Durch die Nutzung von Libcurl, einer angesehenen Bibliothek mit Multi-Protokoll-Dateien, erleichtert PHP Curl effiziente Execu

Alipay PHP ...

Laravel bietet eine kurze HTTP -Antwortsimulationssyntax und vereinfache HTTP -Interaktionstests. Dieser Ansatz reduziert die Code -Redundanz erheblich, während Ihre Testsimulation intuitiver wird. Die grundlegende Implementierung bietet eine Vielzahl von Verknüpfungen zum Antworttyp: Verwenden Sie Illuminate \ Support \ facades \ http; Http :: fake ([ 'Google.com' => 'Hallo Welt',, 'github.com' => ['foo' => 'bar'], 'Forge.laravel.com' =>

Möchten Sie den dringlichsten Problemen Ihrer Kunden in Echtzeit und Sofortlösungen anbieten? Mit Live-Chat können Sie Echtzeitgespräche mit Kunden führen und ihre Probleme sofort lösen. Sie ermöglichen es Ihnen, Ihrem Brauch einen schnelleren Service zu bieten

In Artikel wird die in PHP 5.3 eingeführte LSB -Bindung (LSB) erörtert, die die Laufzeitauflösung der statischen Methode ermöglicht, um eine flexiblere Vererbung zu erfordern. Die praktischen Anwendungen und potenziellen Perfo von LSB

In Artikel werden wichtige Sicherheitsfunktionen in Frameworks erörtert, um vor Schwachstellen zu schützen, einschließlich Eingabevalidierung, Authentifizierung und regelmäßigen Aktualisierungen.

In dem Artikel werden Frameworks hinzugefügt, das sich auf das Verständnis der Architektur, das Identifizieren von Erweiterungspunkten und Best Practices für die Integration und Debuggierung hinzufügen.
