Home Backend Development PHP Tutorial PHP advanced application: header() function sets browser cache_PHP tutorial

PHP advanced application: header() function sets browser cache_PHP tutorial

Jul 13, 2016 pm 05:41 PM
header php function application Browser cache set up advanced

The header() function of PHP advanced application sets the browser cache

This involves 4 header types:
Last-Modified (last modification time);
Expires( Validity period);
Pragma (compilation directive);
Cache-Control (cache control);
The first three headers belong to the HTTP1.0 standard. The Last-Modified header uses UTC date and time values. If the caching system sees that the Last-Modified value is closer to the current time than the cached version of the page, it knows it should use the new version from the server.

Expires indicates when the cached version should expire (GMT). Setting this to a previous time will force the page on the server to be used.

Pragma defines how the page data should be processed. You can avoid caching the page like this:

header("Pragma:no-cache");

Cache-Co0ntrol The header was added in HTTP1.1 and can achieve more detailed Control (should also continue to use HTTP 1.0 headers). There are many
settings for Cache-Control, as shown in the following table:
directive                                                                                                                            Cannot be cached anywhere
must-revalidate The cache must check for an updated version
proxy-revalidate The proxy cache must check for an updated version
max-age The period during which the content can be cached, expressed in seconds
s-maxage Overrides the max-age of the shared cache Age setting
The following example uses header() to set the browser's cache:
// Connect to the database:
$dbc = @mysqli_connect ( localhost, username, password, test) OR die (

Could not connect to the database!

);
// Get the latest dates as timestamps :
$q = SELECT UNIX_TIMESTAMP(MAX(date_added)), UNIX_TIMESTAMP(MAX(date_completed)) FROM tasks;
$r = mysqli_query($dbc, $q);
list($max_a, $ max_c) = mysqli_fetch_array($r, MYSQLI_NUM);
// Determine the greater timestamp:
$max = ($max_a > $max_c) ? $max_a : $max_c;
// Create a cache interval in seconds:
$interval = 60 * 60 * 6; // 6 hours
// Send the header:
header ("Last-Modified: " . gmdate (r, $max));
header ("Expires: " . gmdate ("r", ($max $interval)));
header ("Cache-Control: max-age=$interval");
?>

1. After connecting to the database, obtain the latest date values ​​date_added and date_completed in the data table, use the UNIX_TIMESTAMP() function to convert the return value into an integer and then obtain the maximum value and assign it to $max.

2. Define a reasonable cache time.
$interval=60*60*6
The reasonable value depends on the page itself, the number of visitors and the page update frequency. The above code is 6 hours.

3. Send the Last-Modified header.
header("Last-Modified:".gmdate("r",($max $interval)));
When the gmdate() function uses the parameter "r", it will return the corresponding date according to the HTTP specification Format.

4. Set the Expires header.
header ("Expires: " . gmdate ("r", ($max $interval)));

5. Set the Cache_Control header.
header ("Cache-Control: max-age=$interval");




http://www.bkjia.com/PHPjc/486132.html

www.bkjia.com

http: //www.bkjia.com/PHPjc/486132.htmlTechArticlePHP advanced application header() function sets browser cache, which involves 4 header types: Last-Modified (Last modification time); Expires (validity period); Pragma (compilation instructions); Cache...
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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers Of The Witch Tree - How To Unlock The Grappling Hook
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1669
14
PHP Tutorial
1273
29
C# Tutorial
1256
24
What is the significance of the session_start() function? What is the significance of the session_start() function? May 03, 2025 am 12:18 AM

session_start()iscrucialinPHPformanagingusersessions.1)Itinitiatesanewsessionifnoneexists,2)resumesanexistingsession,and3)setsasessioncookieforcontinuityacrossrequests,enablingapplicationslikeuserauthenticationandpersonalizedcontent.

How to use MySQL functions for data processing and calculation How to use MySQL functions for data processing and calculation Apr 29, 2025 pm 04:21 PM

MySQL functions can be used for data processing and calculation. 1. Basic usage includes string processing, date calculation and mathematical operations. 2. Advanced usage involves combining multiple functions to implement complex operations. 3. Performance optimization requires avoiding the use of functions in the WHERE clause and using GROUPBY and temporary tables.

Composer: The Package Manager for PHP Developers Composer: The Package Manager for PHP Developers May 02, 2025 am 12:23 AM

Composer is a dependency management tool for PHP, and manages project dependencies through composer.json file. 1) parse composer.json to obtain dependency information; 2) parse dependencies to form a dependency tree; 3) download and install dependencies from Packagist to the vendor directory; 4) generate composer.lock file to lock the dependency version to ensure team consistency and project maintainability.

What problems will you encounter when using native select on your phone? What problems will you encounter when using native select on your phone? Apr 30, 2025 pm 03:06 PM

Issues with native select on mobile phones When developing applications on mobile devices, we often encounter scenarios where users need to make choices. Although native sel...

How to configure the character set and collation rules of MySQL How to configure the character set and collation rules of MySQL Apr 29, 2025 pm 04:06 PM

Methods for configuring character sets and collations in MySQL include: 1. Setting the character sets and collations at the server level: SETNAMES'utf8'; SETCHARACTERSETutf8; SETCOLLATION_CONNECTION='utf8_general_ci'; 2. Create a database that uses specific character sets and collations: CREATEDATABASEexample_dbCHARACTERSETutf8COLLATEutf8_general_ci; 3. Specify character sets and collations when creating a table: CREATETABLEexample_table(idINT

Laravel Live Chat Application: WebSocket and Pusher Laravel Live Chat Application: WebSocket and Pusher Apr 30, 2025 pm 02:33 PM

Building a live chat application in Laravel requires using WebSocket and Pusher. The specific steps include: 1) Configure Pusher information in the .env file; 2) Set the broadcasting driver in the broadcasting.php file to Pusher; 3) Subscribe to the Pusher channel and listen to events using LaravelEcho; 4) Send messages through Pusher API; 5) Implement private channel and user authentication; 6) Perform performance optimization and debugging.

How to rename a database in MySQL How to rename a database in MySQL Apr 29, 2025 pm 04:00 PM

Renaming a database in MySQL requires indirect methods. The steps are as follows: 1. Create a new database; 2. Use mysqldump to export the old database; 3. Import the data into the new database; 4. Delete the old database.

Composer's Purpose: Managing Project Dependencies in PHP Composer's Purpose: Managing Project Dependencies in PHP Apr 30, 2025 am 12:01 AM

We need Composer because it can effectively manage dependencies of PHP projects and avoid the hassle of version conflicts and manual library management. Composer declares dependencies through composer.json and uses composer.lock to ensure the version consistency, simplifying the dependency management process and improving project stability and development efficiency.

See all articles