Analysis of php flush class output buffer
for ($i=10; $i>0; $i--)
{
echo $i;
flush();
sleep(1);
}
?>
Follow php According to the manual
This function sends all the output of the program so far to the user's browser.
The above code should output $i every second. But this is not necessarily the case in practice. It is possible that after waiting for 10 seconds, all output is presented at the same time.
Okay, let’s change this code to
ob_end_clean();//Modify part
for ($i=10; $i>0; $i--)
{
echo $ i;
flush();
sleep(1);
}
?>
Hey, after adding this sentence ob_end_clean();, it’s OK. In fact, it is also OK if we replace ob_end_clean() with ob_end_flush().
I will change it again.
for ($i=10; $i>0; $i--)
{
echo $i;
ob_flush();//Modify part
flush();
sleep(1);
}
?>
Run it and find that $i is also output every second? Why is this?
Don’t worry, let’s take a look at php.ini.
Open php.ini, search for output_buffering, we will see a setting like this output_buffering = 4096. Just like its name output_buffering, the function of this setting is to buffer the output. The buffer size is 4096bytes.
In our first piece of code, the reason why the output is not as expected is precisely because this output_buffering buffers all the output. . The output will not be sent before 4096 bytes is reached or the script ends.
The function of ob_end_clean() and ob_end_flush() in the second piece of code is to terminate the buffering. In this way, there is no need to wait until there is a buffer of 4096 bytes before being sent out.
In the third piece of code, ob_flush() is used. Its function is to send the buffered data, but it does not terminate the buffering, so it must be used before each flush().
If we don’t want to use ob_end_clean(), ob_end_flush() and ob_flush(), we must set the output_buffering in php.ini small enough, for example, set to 0. It should be noted that if you plan to use ini_set("output_buffering","0") to set it in a script, then please stop, this method will not work. Because at the beginning of the script, the buffering settings have been loaded, and then buffering starts.
Maybe you may ask, since ob_flush() sends the buffered data, why do you need to use flush()??? Can't you just use the following code? ?
for ($i=10; $i>0; $i--)
{
echo $i;
ob_flush();
sleep(1);
}
?>
Please note The difference between ob_flush() and flush(). The former is to release data from PHP's buffer, and the latter is to send data that is not in the buffer or has been released to the browser. So when the buffer exists, we must use ob_flush() and flush() at the same time.
Is flush() indispensable here? No, we have another method so that when data is output, it will be sent to the browser immediately. The following two pieces of code do not need to use flush(). (When you set output_buffering to 0, you don’t even need ob_flush() and 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;
sleep(1);
}
?>
Please pay attention to ob_implicit_flush(true) above, this function forces whenever there is output , immediately sending the output to the browser. In this way, there is no need to use flush() to send it to the browser after each output (echo).
The above complaint may not be true in some browsers. Because browsers also have their own rules. I used Firefox1.5, IE6, opera8.5 to test. Among them, opera cannot output normally because it has a rule that if it does not encounter an HTML tag, it will never output unless the script ends. FireFox and IE are relatively normal.
At last, I attach a very interesting piece of code, written by PuTTYshell. In a script cycle, each output will overwrite the previous output.
The following code is only available under firefox. Other browsers do not support the Content-Type of 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 "Content-type: text/plainnn";
print "Part $it".$pmt[$i % 4];
print "--endofsectionn";
ob_flush();
flush();
}
print "Content-type: text/plainnn";
print "The endn";
print "--endofsection--n";
?>
For more articles related to php flush class output buffer analysis, please pay attention to PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Alipay PHP...

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...
