IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 如何避免用户使用“过时”的前端网页(强制用户刷新前端网页的方法,非常好用) -> 正文阅读

[JavaScript知识库]如何避免用户使用“过时”的前端网页(强制用户刷新前端网页的方法,非常好用)

需要改造代码,但是能解决no-cache也解决不了的问题

关于前端网页更新的问题,网上的解决方法多是在header的script里的url加入ver、配置nginx的no-cache header等。这些方法解决不了用户已经打开网页,正在使用过时网页的情况。
本文的方法可以在发布新版前端后,立即影响到已经打开的所有网页。

简单、粗暴,但是好用

这里给出了一个非常简单的方式,通过抓取网页中特定的“版本”信息,在每次发起ajax请求时,将版本信息附加到header中。然后后端的springboot接口校验此“版本”信息是否与服务端发布的index.html中的“版本”是否一致,如果不一致则抛出异常。通过控制无法使用后端接口,提示用户刷新网页的方式,实现了强制用户刷新网页的目的。

前端改造方法

在axios的interceptors.request.use中抓取网页的“版本”信息,并设置到header中,下面这个例子是vue3工程中,每次vite build生成的index.html文件的header中第一个script标签的内容。例如其中一个版本的index.html的内容如下:

<!DOCTYPE html>
<html lang="">

<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width,initial-scale=1.0">

  <title>SDP</title>
<script type="module" crossorigin src="/assets/index.bccd869b.js"></script>

如果每次改动代码后使用vite build,每次第一个script标签的内容都会变成新的hash值,所以通过以下js代码即可设置“版本”信息:

        try {
            let html = document.documentElement.outerHTML.split(' src="/assets/index.')
            if (html.length > 1) {
                config.headers.clientversion= html[1].split('.js"></script')[0]
            }
        }catch(ex) {
            console.error('fail', ex)
        }

vue2或其他前端技术,应该都可以通过某种方式获得每次build的唯一“版本”信息。

后端改造方法

在aop的请求切片处理中,校验HttpServletRequest的header,检查其clientversion是否存在于服务端发布的index.html文件中:

    String clientVersion = httpServletRequest.getHeader("clientversion");
    if (StringUtils.isEmpty(clientVersion)) {
        throw new Exception("当前网页版本与服务端不一致,请刷新");
    }
    File f = new File(clientWebPath + "/index.html");
    if (!f.exists()) {
        throw new Exception("index.html文件不存在");
    }
    String content = FileUtil.readFile(f);
    if (content.indexOf(clientVersion) < 0) {
        throw new Exception("当前网页版本与服务端不一致,请刷新");
    }
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-27 10:59:03  更:2022-02-27 10:59:28 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 10:33:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码