vue.js 微信浏览器缓存入口页面index.html问题

本文探讨了微信浏览器中前端更新时遇到的顽固缓存问题,深入分析其成因,并提供两种解决方案:一是变更访问链接,适用于测试环境;二是调整nginx配置,设置特定目录下的资源不被缓存,适用于生产环境。

问题场景:

        1.线上部署nginx直接指向前端文件路径,nginx核心配置如下:

location /front/ {
          try_files $uri $uri/ /front/index.html;
          root /root/html/front;
}

         2.前端每次发布新版时,通过微信浏览器访问原来链接 www.front.com/front/ 总是旧版代码,缓存时间很久。对发版造成严重影响

分析原因:

        因为微信浏览器缓存了www.front.com/front/ 目录下的index.html,css文件,js文件,非常顽固。

解决方案:

       1.改变访问链接www.front.com/front/?v=1123,这种方案线上环境基本不可行,只能在测试环境使用,因为用户端访问链接大部分情况都很难控制,不能通知所有用户去访问新链接

       2.修改nginx配置,设置www.front.com/front/ 不缓存,nginx配置如下

location /front/ {
          try_files $uri $uri/ /front/index.html;
          root /root/html/front;
          #kill 缓存
          add_header Last-Modified $date_gmt;
          add_header Cache-Control 'no-store, no-cache, must-revalidate, proxy-revalidate, max-age=0';
          if_modified_since off;
          expires off;
          etag off;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值