Nginx控制前端静态资源不缓存

本文介绍了在项目中使用Nginx代理前端时遇到的问题——浏览器缓存导致前端代码更新不生效。为解决这个问题,文章提出了通过设置HTTP Header的Cache-control字段为no-cache或no-store来控制不启用缓存,详细解析了两者区别,并提供了修改Nginx配置的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景

项目中使用Nginx代理前端代码,每次前端代码修改完成后,浏览器有时候并不会生效。

原因是很多浏览器做了缓存,导致没有使用最新的前端代码。

解决

通过HTTP Header中的Cache-control字段(no-cache)来控制是否开启缓存。

相关可选项如下:

  • no-cache:客户端可以缓存,但是每次使用缓存资源都必须发请求验证其有效性。如果没有变化返回304,如果发生变化,那理论上就是200。
  • no-store:禁止缓存,不使用任何缓存

修改前的配置:

# 原有静态资源配置
location / {
	root   html/dist;
	index  index.html index.htm;
}

修改后的配置:

# 现有静态资源配置
location / {
	root   html/dist;
	index  index.html index.htm;
  # 可以缓存,没变就用缓存,有变就重新下载
	add_header Cache-control no-cache;
}

参考</

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

甘蓝聊Java

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值