Die Beschreibung von ob_flush/flush im Handbuch besagt, dass beide den Ausgabepuffer aktualisieren und zusammen verwendet werden müssen, was bei vielen Menschen zu Verwirrung führen wird ... In einigen Fällen arbeiten sie tatsächlich mit unterschiedlichen Objekten , Flush macht überhaupt nichts.
Die Funktionen der ob_*-Serie dienen dazu, den Ausgabepuffer von PHP selbst zu betreiben.
Ob_flush dient also dazu, den Puffer von PHP selbst zu aktualisieren.
Und genau genommen hat dies nur dann praktische Auswirkungen, wenn PHP als Modul (Handler oder Filter) von Apache installiert ist.
Es aktualisiert den Puffer von WebServer (der sich speziell auf Apache bezieht).
In Apache Unter dem Sapi des Moduls ruft Flush indirekt die API von Apache auf, indem es den Flush-Member-Funktionszeiger von sapi_module aufruft.
: ap_rflush aktualisiert den Ausgabepuffer von Apache. Natürlich heißt es im Handbuch auch, dass es noch einige andere gibt Module von Apache,
Es kann das Ergebnis dieser Aktion ändern.
Einige Apache-Module, wie z. B. mod_gzip, führen möglicherweise selbst eine Ausgabe-Zwischenspeicherung durch, was dazu führt, dass die von der Funktion „flush()“ generierten Ergebnisse nicht sofort an den Client-Browser gesendet werden.
Sogar der Browser speichert den empfangenen Inhalt zwischen, bevor er ihn anzeigt. Beispielsweise speichert der Netscape-Browser Inhalte zwischen, bis er eine neue Zeile oder den Anfang eines HTML-Tags empfängt, und zeigt die gesamte Tabelle erst an, wenn er das -Tag empfängt.
Einige Versionen von Microsoft Internet Explorer
beginnen mit der Anzeige der Seite erst nach dem Empfang von 256 Bytes, daher müssen einige zusätzliche Leerzeichen gesendet werden, damit diese Browser den Seiteninhalt anzeigen können.
Die richtige Reihenfolge für die Verwendung der beiden ist also: Zuerst ob_flush, dann Flush.
Natürlich können Sie unter anderen Sapi nicht Flush aufrufen, nur um die Portabilität Ihres Codes sicherzustellen Es wird empfohlen, es zusammen zu verwenden.
<?php // set_time_limit(0); header('Content-Type: text/event-stream'); header('Cache-Control: no-cache'); // ob_end_flush(); // ini_set('output_buffering', 0); // ini_set('implicit_flush', 1); if (ob_get_level() == 0) ob_start(); echo str_repeat(' ' ,4096); $long = 60; while($long > 0) { $time = date('r'); echo "data: The server time is: {$time}\n\n"; ob_flush(); flush();//break; sleep(1); $long --; } // var source=new EventSource("http://localhost:18000/sse.php");source.onmessage=function(event){console.info(event.data)}; ?>
Wenn Sie Nginx + FPM + PHP unterstützen möchten, müssen Sie einen Antwortheader hinzufügen
header('X-Accel-Buffering: no' );
Dadurch entfällt sowohl Proxy_buffering als auch (wenn Sie nginx >= 1.5.6 haben) fastcgi_buffering. Das Fastcgi-Bit ist entscheidend, wenn Sie PHP-FPM verwenden
Docs on It wird für das Lernen aller hilfreich sein.
Verwandte Empfehlungen:
phpQuellcode zum Konvertieren von Bildern in Daten/Base64-Datenstrom, detaillierte Erklärung
phpStrategie für die Verbindung zu Microsoft MSSQL (SQL-Server)
Das obige ist der detaillierte Inhalt vonWas Sie bei der Verwendung der PHP-Flush-Funktion beachten sollten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!