Plugins
0

Filename based asset cache busting

LICENSE TYPE: INFINITE

Description

Filename based cache busting for WordPress scripts/styles using last modified date.

Stop telling clients or users to hard refresh / shift refresh. The url to all of the css/js files on your site will change automatically whenever the files are modified. You can set proper long cache lifetimes to help get top scores on Google Pagespeed without running into cached css/javascript problems.

Based on this gist https://gist.github.com/ocean90/1966227 from Dominik Schilling, Ive enhanced it by automatically replacing the asset version with the files modification time and automatically editing htaccess making it install + forget.

Includes querystring option as a fallback which works in more scenarios.

Webservers

Apache

The plugin should add what it needs to your .htaccess file jsut like WP itself. But if for any reason that doesnt work for you heres what it adds:

# FBACB    RewriteEngine On   RewriteBase /    RewriteCond %{REQUEST_FILENAME} !-f   RewriteCond %{REQUEST_FILENAME} !-d   RewriteRule ^(.+).([0-9.]+).(js|css)$ $1.$3 [L]   # still fbacb      ExpiresActive on     ExpiresByType text/css                            "access plus 1 year"     ExpiresByType application/javascript              "access plus 1 year"  # END FBACB 

NGINX

 location ~* ^(.+).(?:d+).(min.js|min.css|js|css)($|?.*$) {    try_files $uri $1.$2;  } 

Host specific notes

Some webhosts need a bit of custom config to get the filename based urls working.

WP Engine

To work on WP-Engine, youll need the following redirect added via my.wpengine -> installname -> Redirect rules

 Source: ^(.+).([0-9.]+).(js|css)$  Dest: $1.$3  Type: break (this is under advanced) 

CloudWays

Just works.

Flywheel

Just works.

PHP Fallback

If your webserver is failing to serve assets using url rewriting, the plugin attempts to serve them itsef (ie: via PHP). Obviously this is slow/less than ideal in production (itll be much slower) so you should configure your web server correctly to serve the files. If you see this HTTP header FBACB-Php-Fallback: yes on your assets, this applies to you.

Note that hosts are increasingly configured to serve css/js directly from disk and wont fall back to PHP + WordPress error handling this fallback then wont work.

Leave a Reply

Your email address will not be published. Required fields are marked *

Fill out this field
Fill out this field
Please enter a valid email address.
You need to agree with the terms to proceed

Most Viewed Posts
Menu