当前位置: 首页 > news >正文

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

文章目录

  • 说明
  • 示例
      • 核心响应头设置
      • 实现原理
      • 代码实现
        • 1. 原生 Node.js (使用 `http` 模块)
        • 2. Express 框架
        • 3. 针对特定路由设置 (Express)
      • 验证方法(使用 cURL)
      • 关键注意事项

说明

日期: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

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

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 标头为 “无缓存、无存储、必须重新验证”,需组合多个响应头以实现严格缓存控制。以下是具体实现方法和代码示例:

核心响应头设置

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 模块)
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 框架
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)
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)

curl -I http://localhost:3000

预期响应头:

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/代理可能忽略这些头部,需额外配置

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

http://www.xdnf.cn/news/865945.html

相关文章:

  • Cursor 工具项目构建指南: Web Vue-Element UI 环境下的 Prompt Rules 约束(new Vue 方式)
  • 杰发科技AC7801——使用内部晶振
  • 极客时间-《搞定音频技术》-学习笔记
  • 大数据学习(128)-数据分析实例
  • Linux开发工具(apt,vim,gcc)
  • Fluence推出“Pointless计划”:五种方式参与RWA算力资产新时代
  • ISO 17387——解读自动驾驶相关标准法规(LCDAS)
  • 网络寻路--图论
  • DeepSeek+SpringAI实现流式对话
  • 读文献先读图:GO弦图怎么看?
  • 概念全解析:结构化数据,半结构化数据,非结构化数据分别是什么意思?
  • 中国区域30m/15天植被覆盖度数据集(2010-2022)
  • 【PDF提取表格】如何提取发票内容文字并导出到Excel表格,并将发票用发票号改名,基于pdf电子发票的应用实现
  • 基于若依前后分离版-用户密码错误锁定
  • 第二章 2.3 数据存储安全风险之数据存储风险防范
  • 湖北理元理律师事务所:债务化解中的心理重建与法律护航
  • 缓存击穿 缓存穿透 缓存雪崩
  • 强制刷新页面和改变当前地址栏地址而不刷新页面
  • Linux随笔
  • C++修炼:C++11(一)
  • [Java 基础]Java 中的关键字
  • Vim查看文件十六进制方法
  • AlphaFold3服务器安装与使用(非docker)(1)
  • 《射频识别(RFID)原理与应用》期末复习 RFID第二章 RFID基础与前端(知识点总结+习题巩固)
  • JAVA-springboot JOSN解析库
  • 华为云Flexus+DeepSeek征文|华为云Flexus服务器dify平台通过自然语言转sql并执行实现电商数据分析
  • 通用寄存器的 “不通用“ 陷阱:AX/CX/DX 的寻址禁区与突围之道
  • 科技创新驱动人工智能,计算中心建设加速产业腾飞​
  • 【设计模式-4.8】行为型——中介者模式
  • 【网络安全】漏洞分析:阿帕奇漏洞学习