Home > Backend Development > PHP Tutorial > Controlling PHP output: caching and compressing dynamic pages_PHP Tutorial

Controlling PHP output: caching and compressing dynamic pages_PHP Tutorial

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Release: 2016-07-21 15:06:59
Original
976 people have browsed it

mod_gzip is an Apache module whose function is to use Gzip to compress static html pages. Browsers that follow the IETF standard can accept gzip encoding (IE, Netscape, etc.). mod_gzip can increase the download time of a page by 4-5 times. I strongly recommend you use mod_gzip on your web server. However, we also had to build our own compression engine in PHP. In this article, I will introduce how to use PHP's output control function to greatly speed up page loading speed.

Introducing PHP’s output control function

The most satisfying thing about PHP4 is that you can let PHP cache all output generated by scripts, and the browser will not receive anything until you decide to send them out. In a script, you can use these functions to set headers and cookies, but this is only a small part of the powerful output functions.

Copy code The code is as follows:

void ob_start(void);
?> ;

Tells the PHP processor to redirect all output to an internal buffer. No output will be sent to the browser until ob_start is called.

Copy code The code is as follows:

string ob_get_contents(void);
?> ;

This function returns the "output buffer" as a string. You can call this function to send the accumulated output to the browser. (Only after turning off the buffering function!!)

Copy code The code is as follows:

int ob_get_length(void);
?> ;

Returns the length of the string in the cache.

Copy code The code is as follows:

void ob_end_clean(void);
?> ;

Clear the output cache and turn off the output cache. This function must be used before the content in the cache is output to the browser.
void 501([int flag])
Used to turn on/off the implicit flush action switch (default is off). If flush is turned on, every time print/echo or other output commands are called, the output content will be immediately sent to the browser.

Use output controls to compress PHP output
You must use the Zlib extension package compiled in PHP4 to compress the output. If necessary, you can view the installation instructions for the Zlib package in the PHP documentation.
First, initialize the output cache:

Copy code The code is as follows:

ob_start();
ob_implicit_flush(0) ;
?>

After that, use print, echo, or any other method you like to generate all output content, for example:

Copy code The code is as follows:

print("Hey this is a compressed output!" );
?>

After the page is generated, we retrieve the output content:

Copy code The code is as follows:

$contents = ob_get_contents();
ob_end_clean ();
?>

After that, it must be detected whether the browser supports compressed data. If supported, the browser will send an ACCEPT-ENCODEING HTTP header to the server. We only need to check if there is a "gzip,deflate" string in the $HTTP_ACCEPT_ENCODING variable.

Copy code The code is as follows:

if(ereg('gzip, deflate',$ HTTP_ACCEPT_ENCODING)) {
// Generate Gzip compressed content here
} else {
echo $contents;
}
?>

This method is simple to use and clearly structured. Let's see how to generate compressed output:

Copy code The code is as follows:

//Tell the browser that the data it will receive is gzip data
//Of course before that, you have checked whether they support gzip, x-gzip data format
//If x-gzip is supported, then the following header must be replaced by z-gzip
header("Content-Encoding: gzip");

//Display the header of the gzip file
//Only displayed once
echo "x1fx8bx08x00x00x00x00x00";

//Calculate the file size and CRC code
$Size = strlen($contents);
$Crc = crc32($contents);

//Compress data
$contents = gzcompress($contents, 9);

//We can’t just output it like this because the CRC code is confusing.
//If I use "echo $contents" here, the compressed data will be sent,
//but it will be incomplete. The last four bytes of the file are CRC check codes, but only three bytes were sent.
//The last byte is lost. I don't know if this bug is solved in version 4.0.2,
//But the best way to avoid errors is to add the correct CRC check code to the end of the compressed data.
//
//Strip the old CRC check code
$contents = substr($contents, 0, strlen($contents) - 4);

//Only display compressed data
echo $contents;

//Output CRC, and the size of the original data (bytes)
gzip_PrintFourChars($Crc);
gzip_PrintFourChars($Size);

function gzip_PrintFourChars($Val) {
for ($i = 0; $i <4; $i ++) {
echo chr($Val % 256);
$Val = floor($Val / 256);
}
}

?>
//Okay, you can also append more compressed data in this way.

For actual testing, all script codes are as follows:

Copy code The code is as follows:

ob_start();
ob_implicit_flush(0) ;

print("I'm compressed!n");

$contents = ob_get_contents();
ob_end_clean();

header("Content-Encoding: gzip");

echo "x1fx8bx08x00x00x00x00x00";

$Size = strlen($contents);
$Crc = crc32($contents);

$contents = gzcompress($contents, 9);

$contents = substr($contents, 0, strlen($contents) - 4);

echo $contents;

gzip_PrintFourChars($Crc);
gzip_PrintFourChars($Size);

function gzip_PrintFourChars($Val) {
for ($i = 0; $i <4; $i ++) {
echo chr($Val % 256);
$Val = floor($Val / 256);
}
}
?>

Cache PHP output

When PHP4 had not yet come out and I had to use PHP3, I was very interested in developing some caching mechanisms to reduce database loading and file system access. There is no particularly good method in PHP3, but with output caching, everything becomes much easier in PHP4.
Here’s a simple example:

Copy code The code is as follows:

//Construct a file name for the requested URI
$cached_file=md5($REQUEST_URI);

if((!file_exists("/cache/$cached_file"))||(!is_valid("/cache/$cached_file"))) {
//is_valid function to verify the cache, you can use this function Check whether the cache has expired or other specific conditions.
//Generate output if the file is not in the Cache or is not available
ob_start();
ob_implicit_flush(0);
//Output here...

$contents = ob_get_contents();
ob_end_clean();
$fil=fopen($cached_file,"w+");
fwrite($fil,$contents,$strlen($contents) );
fclose($fil);
}

/ If the requested file is in cache and available, then:
readfile($cached_file);

?>

This is a simple example, using output caching, you can build a complex content generation system, use different caching mechanisms for different chunks or programs, etc...

Conclusion

PHP output control functions are very useful for redirecting the output generated by scripts to the cache. Outputting cached data for gzip-enabled browsers can reduce load times. It can also be used as a caching mechanism to reduce access to data sources (databases or files), which is of great significance when using XML.
If we build an engine in PHP, cache data from data sources (xml documents and databases), and dynamically generate content in XML format (without appearance-presentation) we can get the output of these XML and use XSLT Convert to any format we want (html, wap, palm, pdf, etc.). This task can be accomplished nicely using PHP4's output caching and the Sablotron XSLT extension.

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/327582.htmlTechArticlemod_gzip is an Apache module. Its function is to use Gzip to compress static html pages. Browsers that follow the IETF standard can Accepts gzip encoding (IE, Netscape, etc.). mod_gzip can convert the page's...
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template