缓存控制HTTP标头设置为“无缓存、无存储、必须重新验证”

文章目录

说明

日期:2025年6月4日。

对于安全内容,请确保缓存控制HTTP标头设置为"no-cache, no-store, must-revalidate"(无缓存、无存储、必须重新验证)。如果应该缓存资产,请考虑将指令设置为"public、max-age、imtable"。

示例

日期:2025年6月4日。

操作系统:ubuntu server v24.04.2 amd64。

应用:

  • node.js v22.15.1
  • npm v11.4.1
  • express(node.js的模块) v5.1.0

直接添加全局中间件设置即可。

javascript 复制代码
const express = require('express');
const app = express();

app.use((req, res, next) => {
  res.setHeader('Cache-Control', 'no-store, no-cache, must-revalidate');
  res.setHeader('Pragma', 'no-cache');
  res.setHeader('Expires', '0');
  next();
});

在 Node.js 应用中设置缓存控制 HTTP 标头为 "无缓存、无存储、必须重新验证",需组合多个响应头以实现严格缓存控制。以下是具体实现方法和代码示例:

核心响应头设置

http 复制代码
Cache-Control: no-store, no-cache, must-revalidate
Pragma: no-cache
Expires: 0

实现原理

  1. Cache-Control: no-store
    禁止任何缓存(包括浏览器和中间代理)
  2. Cache-Control: no-cache
    每次请求必须向服务器验证(即使有缓存)
  3. Cache-Control: must-revalidate
    缓存过期后必须重新验证
  4. Pragma: no-cache(HTTP/1.0 向后兼容)
  5. Expires: 0(设置资源立即过期)

代码实现

1. 原生 Node.js (使用 http 模块)
javascript 复制代码
const http = require('http');

const server = http.createServer((req, res) => {
  // 设置无缓存响应头
  res.setHeader('Cache-Control', 'no-store, no-cache, must-revalidate');
  res.setHeader('Pragma', 'no-cache');
  res.setHeader('Expires', '0');
  
  // 业务响应
  res.end('This content is never cached');
});

server.listen(3000);
2. Express 框架
javascript 复制代码
const express = require('express');
const app = express();

// 全局中间件设置
app.use((req, res, next) => {
  res.setHeader('Cache-Control', 'no-store, no-cache, must-revalidate');
  res.setHeader('Pragma', 'no-cache');
  res.setHeader('Expires', '0');
  next();
});

// 路由示例
app.get('/', (req, res) => {
  res.send('This page is never cached');
});

app.listen(3000);
3. 针对特定路由设置 (Express)
javascript 复制代码
app.get('/sensitive-data', (req, res) => {
  res.set({
    'Cache-Control': 'no-store, no-cache, must-revalidate',
    'Pragma': 'no-cache',
    'Expires': '0'
  });
  res.send('Sensitive data without caching');
});

验证方法(使用 cURL)

bash 复制代码
curl -I http://localhost:3000

预期响应头:

http 复制代码
HTTP/1.1 200 OK
Cache-Control: no-store, no-cache, must-revalidate
Pragma: no-cache
Expires: 0
...

关键注意事项

  1. no-store 优先级最高
    该指令会完全禁用缓存,使其他缓存指令失效
  2. 浏览器兼容性
    Pragma: no-cache 确保兼容旧版 HTTP/1.0 客户端
  3. HTTPS 安全增强
    对敏感内容推荐强制使用 HTTPS 配合缓存控制
  4. 中间代理
    部分 CDN/代理可能忽略这些头部,需额外配置

此配置适用于:登录页面、支付表单、实时数据等需要绝对最新内容的场景。对于静态资源请勿使用此配置,会显著增加服务器负载。

相关推荐
钛态8 小时前
Flutter 三方库 http_mock_adapter — 赋能鸿蒙应用开发的高效率网络接口 Mock 与自动化测试注入引擎(适配鸿蒙 HarmonyOS Next ohos)
android·网络协议·flutter·http·华为·中间件·harmonyos
Augustine Electra8 小时前
Flutter 三方库 memoize 的鸿蒙化实战 - 引入极简缓存引擎,避免重复计算,大幅提升鸿蒙应用渲染性能,让你的高刷体验更稳更丝滑。
flutter·缓存·harmonyos
IT小白310 小时前
windows的VMware虚拟机上的Linux系统(CentOS)配置永久ip(关机重启ip不变)
网络·网络协议·tcp/ip
蛊明12 小时前
批量检测 IP 是否在线:CPing vs QuickPing
网络·网络协议·tcp/ip
路由侠内网穿透.12 小时前
本地部署开源书签管理工具 LinkAce 并实现外部访问( Linux 版本)
linux·运维·服务器·网络·网络协议·开源
闻哥13 小时前
MySQL InnoDB 缓存池(Buffer Pool)详解:原理、结构与链表管理
java·数据结构·数据库·mysql·链表·缓存·面试
gechunlian8813 小时前
redis exporter手册
数据库·redis·缓存
小龙报14 小时前
【数据结构与算法】栈和队列的综合应用:1.用栈实现队列 2.用队列实现栈 3.设计循环队列
c语言·数据结构·数据库·c++·redis·算法·缓存
油丶酸萝卜别吃14 小时前
Redis 通常应用于哪些场景?
数据库·redis·缓存
2301_8059629315 小时前
ESP32远程OTA升级:从局域网到公网部署
网络·后端·http·esp32