PHP buffer is enabled by default, its default parameters are in the php.ini configuration file, and the value is 4096 bytes. Find the output_buffering configuration parameter in it to modify the size of the PHP buffer.
Developers can also manually handle the PHP buffer mechanism in scripts through the ob_start()
function. In this way, even if the output content exceeds the size of the configuration parameters, the data will not be transmitted to the browser. ob_start()
Set the PHP buffer space to be large enough. Only after the script execution ends or is called The ob_end_flush()
function will send the data to the browser.
We edit the php.ini configuration file, modify the output_buffering
value and do the following tests. When output_buffering
is modified to 4096, less data is output, making it smaller than a PHP buffer. The code is as follows:
for ($i = 0; $i< 10; $i++) { echo $i . '<br/>'; sleep($i + 1); //}
After execution, you will find that it will not output every few seconds like conventional logic, but will output all at once until the script loop ends. In this case, the browser interface will remain blank until the script processing is completed. This is because the amount of data is too small and the output buffer is not full. The order of writing data: the echo statement is output to the PHP buffer, TCP buffer, and browser.
Next, we modify output_buffering=0, which still outputs less data, but the actual data is already larger than the PHP buffer. The code is as follows:
for ($i = 0; $i< 10; $i++) { echo $i . '<br/>'; flush(); //通知操作系统底层,尽快把数据发给客户端浏览器 sleep($i + 1); //}
The result of this script must be inconsistent with just now, because the capacity of the buffer is set to 0, that is, the PHP buffer mechanism is disabled. At this time, we will see intermittent output in the browser without having to wait until the script is executed to see the output. This is because the data does not stay in the output cache. The order of writing data is that echo is output to the TCP buffer and then output to the browser. We then change the parameter to output_buffering=4096, and the output data is larger than one buffer. The ob_start() function is not called in this example. Prepare a 4KB file or use the dd command to create a file under the shell:
$dd if=/dev/zero of=f4096 bs=4096 count=1
Use the following code to verify:
for ($i = 0; $i< 10; $i++) { echo file_get_contents('./f4096') . $i . '<br/>'; sleep($i +1); }
You can see that the program response has not ended yet (HTTP connection and not closed), you can see intermittent output, and the browser interface will not remain blank all the time. Although the PHP output buffer mechanism is enabled, there will still be intermittent output instead of one-time output. This is because the PHP buffer space is not enough. Every time a buffer is filled, the data will be sent to the client browser.
The parameters are the same as the above example, that is, output_buffering=4096
, the output data is larger than one PHP buffer. This time we call ob_start()
, the code is as follows:
ob_start(); //开启PHP缓冲区 for ($i = 0; $i< 10; $i++) { echo file_get_contents('./f4096') . $i . '<br/>'; sleep($i + 1); } ob_end_flush();
The complete output will not be seen until the server script is completely processed and the response is completed. The intervals between outputs are so short that no pause is felt. Before outputting, the browser will remain blank, waiting for server-side data. This is because once PHP calls the ob_start()
function, it will expand the PHP buffer to a large enough size and will not send the PHP buffer until the ob_end_flush
function is called or the script ends. data to the client browser.
ob_start
Activate the output_buffering
mechanism. Once activated, the script no longer outputs directly to the browser, but temporarily writes to the PHP buffer first. PHP enables the output_buffering
mechanism by default, and expands the output_buffering
value to a large enough value by calling the ob_start()
function. You can also specify the value of output_buffering
through $chunk_size
. $chunk_size
The default value is 0, which means that the data in the PHP buffer will not be sent to the browser until the script is finished running. If the size of $chunk_size
is set, it means that as long as the data length in the buffer reaches this value, the data in the buffer will be sent to the browser.
You can process the data in the PHP buffer by specifying the $ouput_callback
parameter, such as the function ob_gzhandler()
, which compresses the data in the buffer and then transmits it to browser.
ob_get_contents()
The function is to obtain a copy of the data in the PHP buffer. This is an important function. Please see the following example:
<?phpob_start(); ?> <html> <body>today is <?php echo date('Y-m-d h:i:s'); ?> </body> </html> <?php $output = ob_get_contents(); ob_end_flush();echo '<! output>'.$output;?>
After the above script is run, check the source code, and two identical pieces of HTML will appear. The latter is to obtain the contents of the buffer through the ob_get_contents()
function.
ob_end_flush()
and ob_end_clean()
Both functions will turn off the output buffer.
The difference is that ob_end_flush()
just sends the data in the PHP buffer to the client browser, while ob_clean_clean()
sends the data in the PHP buffer The data is deleted but not sent to the client.
ob_end_flush()
After the call, the data in the PHP buffer still exists, ob_get_contents()
You can still get a copy of the data in the PHP buffer.
The above is the detailed content of Detailed explanation of examples of buffers in php. For more information, please follow other related articles on the PHP Chinese website!

TomakePHPapplicationsfaster,followthesesteps:1)UseOpcodeCachinglikeOPcachetostoreprecompiledscriptbytecode.2)MinimizeDatabaseQueriesbyusingquerycachingandefficientindexing.3)LeveragePHP7 Featuresforbettercodeefficiency.4)ImplementCachingStrategiessuc

ToimprovePHPapplicationspeed,followthesesteps:1)EnableopcodecachingwithAPCutoreducescriptexecutiontime.2)ImplementdatabasequerycachingusingPDOtominimizedatabasehits.3)UseHTTP/2tomultiplexrequestsandreduceconnectionoverhead.4)Limitsessionusagebyclosin

Dependency injection (DI) significantly improves the testability of PHP code by explicitly transitive dependencies. 1) DI decoupling classes and specific implementations make testing and maintenance more flexible. 2) Among the three types, the constructor injects explicit expression dependencies to keep the state consistent. 3) Use DI containers to manage complex dependencies to improve code quality and development efficiency.

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi

PHPisusedforsendingemailsduetoitsbuilt-inmail()functionandsupportivelibrarieslikePHPMailerandSwiftMailer.1)Usethemail()functionforbasicemails,butithaslimitations.2)EmployPHPMailerforadvancedfeatureslikeHTMLemailsandattachments.3)Improvedeliverability

PHP performance bottlenecks can be solved through the following steps: 1) Use Xdebug or Blackfire for performance analysis to find out the problem; 2) Optimize database queries and use caches, such as APCu; 3) Use efficient functions such as array_filter to optimize array operations; 4) Configure OPcache for bytecode cache; 5) Optimize the front-end, such as reducing HTTP requests and optimizing pictures; 6) Continuously monitor and optimize performance. Through these methods, the performance of PHP applications can be significantly improved.

DependencyInjection(DI)inPHPisadesignpatternthatmanagesandreducesclassdependencies,enhancingcodemodularity,testability,andmaintainability.Itallowspassingdependencieslikedatabaseconnectionstoclassesasparameters,facilitatingeasiertestingandscalability.

CachingimprovesPHPperformancebystoringresultsofcomputationsorqueriesforquickretrieval,reducingserverloadandenhancingresponsetimes.Effectivestrategiesinclude:1)Opcodecaching,whichstorescompiledPHPscriptsinmemorytoskipcompilation;2)DatacachingusingMemc


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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

WebStorm Mac version
Useful JavaScript development tools

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

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

Atom editor mac version download
The most popular open source editor
