问题描述
我已将服务器响应配置为在多个端点上包含 Cache-Control: max-age=<some number>
。我在前端使用 Axios 在这些端点上发出 AJAX 请求。当我刷新页面时,一些请求会从浏览器缓存中正确提取,但其中两个总是再次转到服务器。
拒绝从缓存中拉取的总是相同的两个请求。
我检查了浏览器缓存,确实缓存了响应。
Axios 在两个有问题的请求的标头中添加 max-age=0
而不是其他三个,如果我向 Axios 请求添加自定义标头:
let payload = {params: {cik: 999},headers: {'Cache-Control': 'max-age=9999'}};
axios.get('/api/13f-holdings/filer/historical',payload).then((resp) => {
// handle response
});
请求通过以下 Cache-Control
标头:
Cache-Control: max-age=9999,max-age=0
它再次忽略缓存的数据。
鉴于有问题的响应实际上已被浏览器缓存,问题似乎出在 Axios 请求中。但是命中缓存的请求看起来与缺少缓存的请求完全相同。如果我可以提供任何其他信息来帮助诊断此问题,请告诉我。
编辑:我正在使用 VueJS。我注意到在 Vue 组件挂载后会触发两个从未命中浏览器缓存的请求。这很重要吗? Vue 在组件挂载后是否无法立即访问浏览器缓存?
解决方法
这种行为与浏览器开发人员在刷新页面时选择加载数据的方式有关,并且在很大程度上是网站开发人员无法控制的。
如果担心请求没有根据服务器的 Cache-Control
响应头被缓存,可以将请求 URI 粘贴到新标签的地址栏中,并验证页面是否从浏览器缓存加载.
查看这个问题的详细解释:
Why do AJAX GET requests sent from the mounted hook in Vue.js always ignore the browser cache?