How to add expires headers
Expires headers are a great thing to add for all website owners, they speed up load times for your repeat users which is good for everyone.
765 views, 1 RAM, and 0 comments
- What are expires headers?
- How to Add Expires Headers
- Step 1: Open or create a .htaccess
- Step 2: Work out what you want to cache
- Step 3: Write your expires headers rules
- Step 4: Set a default
- Step 5: Save/Upload your .htaccess
- Expires Headers FAQ
- How does Expires Headers work?
- How do I add expires headers to WordPress?
If you're trying to make your website load faster one thing you're going to need to look at is browser caching.
What are expires headers?
Expires Headers will tell the browser if the file needs to be requested from the source and downloaded, or if can be fetched from the browsers cache. This reduces requests for your website as the user will already have those files in their browser cache so theres no need to download that particular file when loading your page.
This greatly increases the speed of your website for repeat visitors and reduces server load.
If you have run your website through a page speed tool such as Pingdom, Google Pagespeed or GT Metrix you will see that all of these recomend implementing expires headers for static content such as images.
How to Add Expires Headers
The easiest method to control your expires headers is through .htaccess
Step 1: Open or create a .htaccess
Before starting you should check if you already have a .htaccess file, if this is the case open it up. If you are not running a .htaccess file please create one. A .htaccess file is a dotfile, these are text based config files for unix systems.
Step 2: Work out what you want to cache
When writing an Expires Header you need to think about two things:
- What files/resources you want to cache
- How long you want to cache things for
Expires Headers work for repeat visitors and they are stored on the client side. Once downloaded and set you have very limited control over things.
This can be bad, for example if you run an ecom store and you cached all your product images for 1 month but you update all your product images users who cached the old version will not see the updated images until it expires.
Think closely about what you're doing with your static files and how they are used before just blanket caching everything. Once you have a plan move on to the next step.
Step 3: Write your expires headers rules
Once you have your list of resources you want to cache, lets write some rules.
Below is the complete block of code, below I will explain it.
Our expires headers rules are placed in a <IfModule> directive. This simply tests if this module is available on your apache set up.
<IfModule mod_expires.c> #rules in here </IfModule>
If you know for a fact that it's available and activated, you don't need this but there are many hosts who turn this feature off as standard. It's good practice to keep it though, especially if playing around in staging enviroments which may not have cache activated.
Next up we have to turn on ExpiresActive, this makes it work.
Next up we actually get to the rules. Rules are split into two main parts, first we specify the files we want to target and then we set how long the header rule should stand for.
Above is an example of many of the types of file you may want to cache.
ExpiresByType allows us to select types of files.
Next up we need the file type and encoding.
Finally in quotes we set the time from access. "access plus 1 month" will set the header to expire 1 month from when the file was first accessed by the user.
Step 4: Set a default
It's worth considering to set a default catch all rule as well for files you don't specify.
This is done like so:
ExpiresDefault "access plus 2 days"
Step 5: Save/Upload your .htaccess
Finally either save your .htaccess file or upload it if you wern't using one before.
Expires Headers FAQ
How does Expires Headers work?
Expires Headers tell web browsers how long they should store certain files. These files are stored locally for your users so when users visit websites repeatedly and you have expires headers set up properly these files are going to load far quicker for your user and because theres no need to re-download them they reduce load and requests on your server.
Expires Headers are specifically for return users, they do not help users who visit your website first time round.
You can set these rules by type or by specific files.
How do I add expires headers to WordPress?
Follow the tutorial above and add the code to the WordPress default .htaccess at the bottom of the file. It will work in the exact same way.
You can do it also with a plugin, but you're an idiot if you do it this way. These plugins offer limited control over expiration times and will slow down your website and clog your WordPress database.
- How to block certain websites on your computer
- [PHP] How to Add rel="nofollow", rel="nofollow ugc", rel="nofollow sponsored" and/or Other rel Attributes to L...
- How to use GZip compression on your website
- How to add expires headers
- Preventing Hotlinking with .htaccess
- [PHP] Embed and Autolink Everything with One Function Call: Vimeo, YouTube, DailyMotion, Imgur, and Gyazo
- Scoring Big Links From Authority Sites
- All PHP Timezones, Timezone Abbreviations, Offsets, and Daylight Savings Time Data
- How to Parse a User Agent in PHP with Minimal Effort
- Best PHP Frameworks
Some other content you may like:
Post a New Comment
Do you like having a good time?
Register an Account
Read Quality Articles
Read some quality articles. If you can manage to not get banned for like five minutes, you can even post your own articles.
Argue with People on the Internet
Use your account to explain why people are wrong on the Internet forum.
Vandalize the Wiki
Or don't. I'm not your dad.
Ask and/or Answer Questions
If someone asks a terrible question, post a LMGTFY link.
Make Some Money
Hire freelancers and/or advertise your goods and/or services. Hire people directly. We're not a middleman or your dad. Manage your own business transactions.