How to Add Expires Headers in WordPress

Expired headers play an important role in website performance, and WordPress websites are no exception. Expired headers can significantly reduce server load times and improve website responsiveness by instructing web browsers how long to cache static resources like images, CSS, and JavaScript. If the Expires header is absent the browser will determine the cache lifetime based on its policies.

In this post, we will discuss understanding WordPress add expires headers by exploring effective methods with the .htaccess file using Apache or Nginx and the solution is based on WordPress plugins.

Understanding Expires Headers

When a user visits a WordPress site for the first time their browser downloads all the necessary resources like images, stylesheets, and scripts. These resources are then stored in the browser’s cache. On subsequent visits, the browser checks the WordPress cache expiration header associated with each resource. If the resource has not expired the browser retrieves it from the cache saving valuable time and bandwidth.

Adding Expires Headers via the .htaccess File on the Apache Server

Most WordPress servers use Apache this method requires editing the .htaccess file which is located in your website’s root directory. It is important to back up your .htaccess file before making any changes as incorrect modifications can break your website.

Access your .htaccess file: You can access the .htaccess file using an FTP client or file manager from cPanel. Remember .htaccess file is a hidden file so the “show hidden file” option should be enabled to view it. For this tutorial, I am using cPanel to access .htaccess file.

.htaccess file


Edit the .htaccess file: Open the .htaccess file in a text editor and paste the following code:

<IfModule mod_expires.c>
ExpiresActive On
ExpiresByType text/html "access 1 month"
ExpiresByType text/css "access 1 month"
ExpiresByType text/javascript "access 1 month"
ExpiresByType image/jpg "access 1 year"
ExpiresByType image/png "access 1 year"
ExpiresByType image/gif "access 1 year"
# Add expires headers for other file types as needed
</IfModule>

This code configures the server to actively set expires headers WordPress. It also specifies expiration times for various file types. You can adjust the expiration times for example, “1 month” or “1 year” based on your preferences and the update frequency of your website’s content.

edit .htaccess


Save the changes: Save the .htaccess file and upload it back to your server if using an FTP client.

Adding Expires Headers via the .htaccess File on the Nginx Server

Adding expires headers in Nginx allows you to instruct web browsers on how long to cache static resources like images, CSS, and JavaScript files. This can significantly improve website performance by reducing server load and speeding up page load times. Here’s how to implement expires headers in your Nginx configuration:

Locate your Nginx configuration file: The location of your Nginx configuration file may vary depending on your setup. Mostly it is found in /etc/nginx/nginx.conf locations by default:

Edit the configuration file: Use a text editor like nano or vim to open the Nginx configuration file.

Add the expires headers block: Within the server block for your website, locate the section where you define location blocks for specific directories or files. Add the following code snippet inside a location block that matches the static resources you want to set expires headers for:

location ~* \.(?:ico|css|js|gif|jpe?g|png|svg|woff)$ {
  expires 30d;  # Set expiration time to 30 days (adjust as needed)
  add_header Pragma public;
  add_header Cache-Control "public";
}

This regular expression matches URLs that end with common static file extensions. Expires sets the expiration time for matched resources to 30 days. You can adjust this value based on your needs. The Pragma header to public, indicating the resource can be cached by any proxy server. The Cache-Control header to public, allowing browsers and other caches to store the resource for the specified expiration time.

Save and test your configuration: Save the changes to your Nginx configuration file. Validate your configuration for syntax errors by running the following command:

sudo nginx -t

Adding Expires Headers with Plugins

For a more user-friendly approach, you can take advantage of several WordPress plugins that enable adding expires headers. Here’s a popular option:

  1. Install and activate a plugin: A popular choice is “WP Rocket”. Search for the plugin name in your WordPress dashboard then click “Install Now and “Activate” the plugin.
  2. Configure the plugin settings: Access the plugin’s settings page and enable the option to set expires headers. You can typically define expiration times for different file types within the plugin’s interface.

Testing and Verification

Once you’ve implemented expires headers, it’s recommended to test their effectiveness. You can use online tools like GTmetrix to check if expires headers are being sent for your website’s resources.

Conclusion

Adding expires headers is a simple yet powerful technique to improve website performance WordPress. By implementing the methods outlined above, you can instruct browsers to website cache static resources effectively, leading to faster loading times and a more efficient user experience.

While adding expires headers can improve website performance it might not be the solution for all websites. If you are experiencing persistent performance issues, consider upgrading to Ultahost’s VPS hosting plan. Our offer includes dedicated resources and greater control allowing you to optimize your website for peak performance.

FAQ

What are Expires Headers in WordPress?
Why should I add Expires Headers?
Is it difficult to implement Expires Headers?
What benefits come with Expires Headers?

Related Post

How to Combine External Javascript and CSS in

Combining external JavaScript and CSS files in WordPres...

How to Enable GZIP Compression to Maximize We

GZIP compression is a powerful technique that can signi...

How to Display Related Posts in WordPress

Engaging your readers and keeping them on your WordPres...

How to Fix “Serve Static Content From a Coo

Have you encountered the "Serve Static Content From a C...

How to Change Permalink in WordPress

Permalinks, short for "permanent links" are the URLs us...

How to Redirect non-www to www URLs

Redirecting non-www to www URLs is a common task for sy...

Leave a Comment