前端保持和服务器时间同步的方法【使用vue3举例】

你只管努力!剩下的交给时间!

目录

引言:

保持前端与服务器时间同步是一个常见的需求,特别是在需要确保时间一致性的应用中,比如在线投票、实时聊天或游戏等。以下是一些方法来实现这一目标:

方法一: 轮询(定时请求服务器时间)

可以定时向服务器发送请求获取当前时间,以此来更新前端的时间显示。

<template><div><h1>当前时间:{{ currentTime }}</h1></div></template><script lang="ts" setup>import{ ref, onMounted, onUnmounted }from'vue';const currentTime =ref('');let intervalId;constfetchServerTime=async()=>{try{const response =awaitfetch('/api/server-time');// 替换为实际的API地址const data =await response.json(); currentTime.value =newDate(data.serverTime).toLocaleString();}catch(error){ console.error('获取服务器时间失败:', error);}};onMounted(()=>{fetchServerTime(); intervalId =setInterval(fetchServerTime,60000);// 每分钟请求一次});onUnmounted(()=>{clearInterval(intervalId);});</script>

优点:

  • 实现简单,易于理解和使用。
  • 适用于不需要高频率更新的场景。

缺点:

  • 可能导致服务器负担增加,尤其是在用户量大的情况下。
  • 网络延迟可能导致时间不够准确。
  • 需要处理网络错误和重试逻辑。

方法二:使用WebSocket

当我们需要实时更新,可以使用WebSocket来保持与服务器的连接,当服务器时间变化时,前端可以立即收到更新。

<template><div><h1>当前时间:{{ currentTime }}</h1></div></template><script lang="ts" setup>import{ ref, onMounted, onUnmounted }from'vue';const currentTime =ref('');let socket;constupdateTime=(time)=>{ currentTime.value =newDate(time).toLocaleString();};onMounted(()=>{ socket =newWebSocket('ws://your-websocket-url');// 替换为实际的WebSocket地址 socket.onmessage=(event)=>{const data =JSON.parse(event.data);updateTime(data.serverTime);}; socket.onopen=()=>{ console.log('WebSocket连接已打开');}; socket.onclose=()=>{ console.log('WebSocket连接已关闭');};});onUnmounted(()=>{if(socket){ socket.close();// 关闭WebSocket连接}});</script>

优点:

  • 提供全双工通信,适合实时应用。
  • 一旦建立连接,可以持续接收时间更新,减少请求次数。
  • 可以推送其他实时数据,适用场景广泛。

缺点:

  • 实现相对复杂,需要处理连接管理和状态维护。
  • 需要服务器支持WebSocket。
  • 如果连接中断,需要重新建立连接。

方法三:时间戳校正

在用户首次加载页面时获取服务器时间,并根据本地时间与服务器时间的差异进行校正。我们可以使用本地时间加上这个差异来显示时间。

<template><div><h1>校正后的当前时间:{{ correctedTime }}</h1></div></template><script lang="ts" setup>import{ ref, onMounted }from'vue';const correctedTime =ref('');let timeOffset =0;constfetchServerTime=async()=>{try{const response =awaitfetch('/api/server-time');// 替换为实际的API地址const data =await response.json();const serverTime =newDate(data.serverTime).getTime();const localTime = Date.now(); timeOffset = serverTime - localTime;// 计算时间差}catch(error){ console.error('获取服务器时间失败:', error);}};constupdateCorrectedTime=()=>{const now =newDate(Date.now()+ timeOffset); correctedTime.value = now.toLocaleString();};onMounted(()=>{fetchServerTime().then(()=>{updateCorrectedTime();setInterval(updateCorrectedTime,1000);// 每秒更新一次});});</script>

优点:

  • 可以在本地计算时间,减少对服务器的依赖。
  • 可以通过简单的数学运算来保持时间同步。

缺点:

  • 依赖于本地时间的准确性,可能因用户设备时间不准确而导致问题。
  • 需要定期校正,可能会引入延迟。

方法四: 使用NTP(网络时间协议)

NTP是一种用于同步计算机时钟的协议。虽然NTP通常在服务器端配置,但我们也可以通过调用NTP服务来获取准确的时间。可以使用一些公共的NTP API,例如 ntpjs 库来实现。

<template><div><h1>当前时间:{{ currentTime }}</h1></div></template><script lang="ts" setup>import{ ref, onMounted }from'vue';import{ NTPClient }from'ntpjs';// 需要安装ntpjs库const currentTime =ref('');constfetchNTPTime=async()=>{const client =newNTPClient();try{const time =await client.getTime(); currentTime.value =newDate(time).toLocaleString();}catch(error){ console.error('获取NTP时间失败:', error);}};onMounted(()=>{fetchNTPTime();setInterval(fetchNTPTime,60000);// 每分钟请求一次});</script>

优点:

  • 提供高精度时间同步,适合需要准确时间的应用。
  • 可以通过公共NTP服务器获取时间,减少服务器负担。

缺点:

  • 实现相对复杂,需处理NTP请求和解析。
  • 可能需要额外的网络请求,增加延迟。
  • NTP服务器的可用性和响应速度可能影响结果。

方法五:使用SSE(Server-Sent Events)

SSE是一种允许服务器推送实时更新到客户端的技术,适合用于实时数据流,如时间更新。

<template><div><h1>当前时间:{{ currentTime }}</h1></div></template><script lang="ts" setup>import{ ref, onMounted, onUnmounted }from'vue';const currentTime =ref('');let eventSource;onMounted(()=>{ eventSource =newEventSource('/api/time-stream');// 替换为实际的SSE地址 eventSource.onmessage=(event)=>{const data =JSON.parse(event.data); currentTime.value =newDate(data.serverTime).toLocaleString();// 假设服务器发送的时间为ISO格式}; eventSource.onerror=(error)=>{ console.error('SSE连接错误:', error);};});onUnmounted(()=>{if(eventSource){ eventSource.close();// 关闭SSE连接}});</script>

优点:

  • 适合实时数据推送,能够持续接收时间更新。
  • 实现相对简单,基于HTTP协议,易于使用。

缺点:

  • 只支持单向通信(从服务器到客户端),适用场景有限。
  • 需要服务器支持SSE。
  • 如果连接中断,需要重新建立连接,可能导致时间延迟。

总结:

  • 如果需要高精度时间NTP是最佳选择。
  • 如果需要实时更新WebSocketSSE是合适的。
  • 对于简单应用定期请求服务器时间时间戳校正可能是最简单的解决方案。

Read more

从零开始:在本地搭建一个带知识库的 AI 助手(Ollama + Open WebUI)

从零开始:在本地搭建一个带知识库的 AI 助手(Ollama + Open WebUI)

一文讲清楚:要选哪些工具、需要什么环境、整体架构长什么样,以及一步步实现到能用的程度。 一、为什么要在本地搭一个 AI 助手? 过去一年,大模型从“新奇玩意儿”迅速变成“日常生产力工具”。但如果你只用网页版 ChatGPT / 文心一言 / 通义千问,会碰到几个很现实的问题: * 数据隐私:公司内部文档、个人笔记、聊天记录,你敢全部塞到线上吗? * 网络依赖:在飞机上、高铁里,或者公司内网严格管控时,在线 AI 直接“失联”。 * 额度与费用:免费额度有限,稍微重度一点就要付费,而且你也不知道自己的数据会不会被拿去训练。 本地部署一套 “AI + 知识库” 的好处就非常直观: 1. 数据完全不出本地,满足隐私合规要求。 2. 断网也能用,随时随地调取你的“第二大脑”。 3. 可定制:可以给团队搭一个“

By Ne0inhk
Flutter for OpenHarmony: Flutter 三方库 sanitize_html 彻底杜绝 XSS 注入风险(鸿蒙 Web 内容安全净化)

Flutter for OpenHarmony: Flutter 三方库 sanitize_html 彻底杜绝 XSS 注入风险(鸿蒙 Web 内容安全净化)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在开发 OpenHarmony 应用时,如果我们需要在 UI 中渲染来自后端的 HTML 内容(例如文章正文、用户评论),或者使用 flutter_html 等库,一个致命的安全风险就是 XSS (跨站脚本攻击)。恶意代码可能会通过 <script> 标签或 onerror 属性在你的 App 内执行非法逻辑。 sanitize_html 是一个轻量级且极高效的 HTML 净化库。它采用白名单机制,能瞬间过滤掉所有不安全的标签和属性,确保你在鸿蒙 App 内渲染的每一行 Web 内容都是绝对安全的。 一、核心防御机制解析 sanitize_html 遵循“默认拒绝”

By Ne0inhk
前端异常捕获与统一格式化:从 console.log(error) 到服务端上报

前端异常捕获与统一格式化:从 console.log(error) 到服务端上报

🧑 博主简介:ZEEKLOG博客专家,「历代文学网」(公益文学网,PC端可以访问:https://lidaiwenxue.com/#/?__c=1000,移动端可关注公众号 “ 心海云图 ” 微信小程序搜索“历代文学”)总架构师,首席架构师,也是联合创始人!16年工作经验,精通Java编程,高并发设计,分布式系统架构设计,Springboot和微服务,熟悉Linux,ESXI虚拟化以及云原生Docker和K8s,热衷于探索科技的边界,并将理论知识转化为实际应用。保持对新技术的好奇心,乐于分享所学,希望通过我的实践经历和见解,启发他人的创新思维。在这里,我希望能与志同道合的朋友交流探讨,共同进步,一起在技术的世界里不断学习成长。 🤝商务合作:请搜索或扫码关注微信公众号 “ 心海云图 ” 前端异常捕获与统一格式化:从 console.log(error) 到服务端上报 引言 在前端开发中,异常监控是保证应用稳定性的重要一环。当用户遇到页面白屏、功能不可用等问题时,如果能及时收集到详细的错误信息(包括堆栈、

By Ne0inhk
【AI深究】逻辑回归(Logistic Regression)全网最详细全流程详解与案例(附大量Python代码演示)| 数学原理、案例流程、代码演示及结果解读 | 决策边界、正则化、优缺点及工程建议

【AI深究】逻辑回归(Logistic Regression)全网最详细全流程详解与案例(附大量Python代码演示)| 数学原理、案例流程、代码演示及结果解读 | 决策边界、正则化、优缺点及工程建议

大家好,我是爱酱。本篇将系统讲解——逻辑回归(Logistic Regression)的原理、公式、案例流程、代码实现和工程建议。内容详细分步,便于新手和进阶读者理解和实操。 注:本文章含大量数学算式、详细例子说明及大量代码演示,大量干货,建议先收藏再慢慢观看理解。新频道发展不易,你们的每个赞、收藏跟转发都是我继续分享的动力! 注:本文章颇长近5000字、以及大量Python代码、非常耗时制作,建议先收藏再慢慢观看。新频道发展不易,你们的每个赞、收藏跟转发都是我继续分享的动力! 一、逻辑回归简介 逻辑回归是一种经典的线性分类算法,本质上是用Sigmoid函数将线性回归的输出“压缩”到0~1之间,输出为概率,常用于二分类任务。 与KNN(K-近邻算法)不同,逻辑回归是判别式模型,直接建模输入特征与类别之间的概率关系,适合特征和类别呈线性可分或近似线性关系的数据。 注:爱酱也有文章介绍了分类以及其他五大任务的技巧,有兴趣的也可以参考一下哦~ 分类任务文章传送门: 【算法解析1/5】分类任务深度拆解:

By Ne0inhk