| 4:23 pm on Jul 1, 2014 (gmt 0)|
I don't think so:
Notice the period . at the end of the image/x-icon where the close " should be. You would have an error using that. It may not show up as an error, but it can't work as expected.
|ExpiresByType text/plain "access plus 1 month" |
ExpiresByType image/x-icon "access plus 1 year.
Back to the top, what purpose does this serve if it goes on to increase that in the next set of Expires and use an unspecified format? I understand this is an inherited problem, just trying to understand the reason behind it. I would not be surprised to find that nothing is being cached or else everything is 2 weeks only.
|# Cache all files for 2 weeks after access (A). |
It looks like they are mixing directives and adding in typos.
The ExpiresDefault (Default expiration number and format) sets up the format you plan to use.
The ExpiresByType directive allows you to specify MIME-type and then the kind of number, then the number. The "kind of number" refers to the declaration above where it specifies A (access or now) followed by the number of seconds in two weeks..Then it goes on to throw all that out and use a different format than the one that was set.
Some advice is to double the number shown in your ExpiresDefault A1209600 to A2419200 and take out the rest below that so everything defaults to 1 month if that is the object.
Best advice is to read the documentation and decide which format works best for you and replace all of that with the proper instructions. For Apache 2.4 that information is here: [httpd.apache.org...]
| 5:15 pm on Jul 1, 2014 (gmt 0)|
Thank you taking a look at this. I actually inherited the site from a group of outsourced developers so I'm not actually sure what the purpose of setting the Default is when everything is changed in the next mod_expires group. Could it be to just have a default fall back in case an asset is undefined?
| 6:37 pm on Jul 1, 2014 (gmt 0)|
Temporarily turn off caching for the .js MIME-type and then after the amount of time that it would have expired anyway (say 2 weeks) you can reset .js to have a longer Expiration time. Downside is temporarily slower page loads as every page needs to request a new copy of the .js file and slightly higher bandwidth for the extra requests if that is any issue at all.
The other option is more work for you but handles it easily and faster for users: Upload the corrected script with a new name and update the site to request the new .js file. In this method, a lot depends on how your site is structured (is the .js part of an include that can be updated in one file only - are the pages dynamically or statically generated - is there a CMS involved - or is it a page by page project to change the src="filename.js" request?) If you have the right tools, you can do find/replace actions throughout all related files with one click, if you don't, it is tedious work.
Others may have better suggestions, but you can see that it largely depends on how and where this script is used for the options mentioned.
| 6:47 pm on Jul 1, 2014 (gmt 0)|
| 3:54 pm on Aug 8, 2014 (gmt 0)|
Reading through the Google developer docs to Optimize caching, they recommend "fingerprinting". I was hoping to simply add a query string to the end of the url e.g., styles.css?v=12, would also be an effective solution but it looks like that is not recommended.
[edited by: engine at 4:47 pm (utc) on Aug 8, 2014]
[edit reason] fixed url [/edit]
| 4:31 pm on Aug 8, 2014 (gmt 0)|
Fingerprinting might be the best way to go for you if your pages are dynamically generated. As mentioned before, the right answer depends on the question. You know what kind of platform you use for your site. The best answer for static html is not the best answer for AJAX for example.
Fingerprinting never interested me because Cache control headers does fine for my sites and gives me control based on file type. I can't help with ETAG generation, sorry. The Link you posted is where I got my information also. :)
| 4:49 pm on Aug 8, 2014 (gmt 0)|
So for something like a WordPress or Drupal site the best approach would probably be fingerprinting?