Hi @jglazer63
The caching at Facebook is indeed a great annoyance.
Changing the file-name will not help you. Well, it would, but it’s not an easy thing to do; The filename is not a filename per-sé, it could also be ‘hello-world’ or ‘19234o8734’. The URL used for the images is a URL-endpoint and those are static as they are saved in the WordPress Rewrite Rules. If you change it now to ‘social-image-2’, all the other cached URLs no longer work. What would be needed is a dynamic URL.
This cannot be achieved using WordPress’ add_rewrite_endpoint
function. This does not mean it cannot be done, there are ways to make a dynamic endpoint, namely using custom rewrite rules, but I’d rather stick to WordPress functionality to keep the plugin understandable for other developers.
There is an alternative, and, as it turns out, your question has been asked before; https://www.ads-software.com/support/topic/request-add-timestamps-or-random-string-to-image-urls/
With an MU-Plugin or an addition to the functions.php of your theme, you can Implement a filter like this:
add_filter('bsi_image_url', function($url) { return add_query_arg('_', time(), $url); });
This will add a URL parameter with the timestamp to the image URL, which most probably will solve the caching issue. This is not the default plugin behaviour as it will essentially disable caching entirely.
As to your remark on the trailing slash being a problem; well, it’s not. It never has been and because the plugin uses default WordPress functionality, it never will be. As indicated above, the filename is not a real filename. it’s just an endpoint identifier, it could be anything. But, in true WordPress fashion, the trailing slash is unavoidable.
Using the bsi_image_url filter, you can remove the trailing slash (combined with adding the cachebuster parameter);
add_filter('bsi_image_url', function($url) { return add_query_arg('_', time(), untrailingslashit($url) ); });
(or just the slash removal)
add_filter('bsi_image_url', function($url) { return untrailingslashit($url); });
These URLs without trailing slash will work, but because of WordPress requiring the trailing slash, this will result in a redirect to the same URL _with_ a trailing slash. Your URLs may look better in the webpage source HTML, but the performance will be worse because of the inevitable redirect.
Using a completely custom endpoint handling it is possible to remove the trailing slash entirely, but then we run the risk of breaking in a future WordPress update, so I choose to stay 100% WordPress compatible, consequence being that the annoying trailing slash will stay. Unfortunately.