zoukankan      html  css  js  c++  java
  • moment.js 默认使用服务器时间

    在前端使用Date对象获取当前时间的时候,该时间是客户端的时间。但是该时间可以被用户修改,所以我们一般情况下并不想要这个时间。如果每一次获取时间的时候都请求一下服务器,那么将会对服务器造成不必要的压力,我们也不想这么做。在网上找了一圈之后,发现了一些解决方案,就在这里总结一下

    1.当系统被用户第一次打开的时候,发送请求(没必要写一个专门获取时间的API),根据http的相应头Date字段获取服务器时间。此时与客户端时间做差,并将差值记录下来。

    2.为了防止客户端时间被用户修改,我们每隔2s(这个自定义吧)获取一下客户端时间,并将上一个时间和当前时间做差,看和2s差的大不大,正常情况下也就是几十毫秒的差值,我们在这里比方设为 1s。如果差值大于1s,我们就认为客户端时间被修改了,我们此时获取一下前一个时间和当前时间的差值再减去2s就是修改时候后的差值。

    3.moment.js内部获取时间是使用的moment.now方法,我们把这个方法自定义一下就可以了

    以下是代码实现:

    	var diff = 0;           // 记录服务器和客户端的时间差值
    	var lastTime;           // 记录上一次时间
        $(function(){
            $.ajax({
                url: apiURL,
            }).always(function(res, state, xhr){
                var serverTime = new Date(xhr.getResponseHeader("Date")).getTime();
                var localTime = +new Date;
                diff = serverTime - localTime;
                lastTime = localTime;
                var InvertialMillSeconds = 2000;
                var maxMillSeconds = 1000;
                // 每InvertialSeconds毫秒检测一次当前时间,
                // 若差值大于maxMillSeconds那么可以判断出客户端时间被修改了
                setTimeout(function(){
                    var nowTime = +new Date;
                    var InverDiff = nowTime - (lastTime + InvertialMillSeconds);
                    if(Math.abs(InverDiff) > maxMillSeconds){
                        diff += InverDiff;
                    }
                    lastTime = nowTime;
                    setTimeout(arguments.callee, InvertialMillSeconds);
                }, InvertialMillSeconds);
            })
            
        })
    	
    

    moment.now本来是这个样子的

    	var now = function() {
            return Date.now ? Date.now() : +(new Date());
        };
    

    我们在引入moment.js之后,重新修改该值为

    	if (window.moment && window.moment.now) {
            moment.now = function(){
                return Date.now ? Date.now()+top.diff : (new Date().getTime() + top.diff);
            }
        }
    

    到此,大功告成!

    本文由博客一文多发平台 OpenWrite 发布!

  • 相关阅读:
    读写文件流
    关闭和退出窗口
    有什么问题?
    将aspx页面转换成htm页面
    读取rss聚合文件
    运算符重载实例
    委托
    将 Visual Studio .NET 调试器用于 ASP.NET 应用程序
    输入的字符串进行有规则的清洗
    几个常用的数据库连接字符串
  • 原文地址:https://www.cnblogs.com/theone67/p/12050776.html
Copyright © 2011-2022 走看看