gpt4 book ai didi

javascript - Axios GET 请求忽略响应 Cache-Control max-age

转载 作者:行者123 更新时间:2023-12-05 06:06:50 25 4
gpt4 key购买 nike

我已将我的服务器响应配置为包含 Cache-Control: max-age=<some number>在几个端点上。我在前端使用 Axios 在这些端点上发出 AJAX 请求。当我刷新页面时,一些请求会从浏览器缓存中正确提取,但其中两个总是会再次发送到服务器。

拒绝从缓存中拉取的总是相同的两个请求。
我检查了浏览器缓存,确实缓存了响应。
Axios 添加 max-age=0在两个有问题的请求的 header 中,但不是其他三个请求的 header ,如果我向 Axios 请求添加自定义 header :

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 响应 header 进行缓存,则可以将请求 URI 粘贴到新选项卡的地址栏中,并验证该页面是从浏览器缓存加载。

有关详细说明,请参阅此问题:

Why do AJAX GET requests sent from the mounted hook in Vue.js always ignore the browser cache?

关于javascript - Axios GET 请求忽略响应 Cache-Control max-age,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65649378/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com