记录IIS服务容器中前端资源缓存问题的解决过程

1、系统架构

2、遇到的问题

     发布新版本后,浏览器未获取最新资源,手动刷新页面,获取到最新的资源。重新打开浏览器,浏览器依旧未获取到最新资源。

3、问题分析

    发版后浏览器打开系统,直接取的是浏览器本地缓存,未向服务端确认资源是否已改变

更新前:

  更新后:

拓展:可利用工具 ChromeCacheView 查看chrome浏览器的缓存数据

4、解决思路

    让浏览器每次打开页面都向服务器确认资源是否已更新。

    配置IIS服务容器,使请求返回的headers中增加Cache-Control:no-cache关键字

    方式一:

        IIS 网站的功能视图  -> HTTP 响应标头

 

方式二:

web.config文件增加节点

        <httpProtocol>
            <customHeaders>
                <add name="Cache-Control" value="no-cache" />
            </customHeaders>
        </httpProtocol>

说明:web.config 生效范围是当前目录及同级目录子目录下的资源,因此可以选择性的配置指定目录资源缓存方式

5、增加Cache-Control后的效果

浏览器每次都会向服务器确认资源是否更新,未更新则使用本地缓存,已更新则获取最新资源    

第一次访问:

未更新再次访问:

更新后访问:

更新资源后发起请求

参考资料:

彻底理解浏览器的缓存机制(http缓存机制)

 

 

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

YBeagle

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

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

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

打赏作者

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

抵扣说明:

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

余额充值