• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
好多前端攻城师
梦1106
博客园    首页    新随笔    联系   管理    订阅  订阅

使用javascript获取服务器时间

思路:采用异步请求的方式,发送请求,获取HTTP请求的response头,头部中包含时间,使用getResponseHeader('Date')即可。

注意:以下任何一种方法都不精确,因为请求包的传输时间依赖于网络状况,在较差网络下会有误差。方法三允许人工调整误差时间。

1.方法一

通过发送GET请求同步获取时间

var xmlHttp = new XMLHttpRequest();

xmlHttp.open("GET", location.href, false); //同步
xmlHttp.setRequestHeader("Range", "bytes=-1");
xmlHttp.send(null);
severtime=new Date(xmlHttp.getResponseHeader("Date"));

 

2.方法二

通过发送HEAD请求异步获取时间。

var xhr = new XMLHttpRequest();
/*if( !xhr ){
   xhr = new ActiveXObject("Microsoft.XMLHTTP");
}*/
xhr.open("HEAD",location.href,true); //异步
xhr.onreadystatechange=function(){
    if( xhr.readyState == 4 && xhr.status == 200 ){
         alert(xhr.getResponseHeader("Date"));
    }
}
xhr.send(null);

这种方法依赖服务器配置,大多数服务器出于安全考虑会禁止这种HEAD请求,返回405错误。在控制台内可看到报错,但是不影响结果嘛。

 

3.方法三 插件

在github上查到一个写好的比较完整的插件,可以配置选择同步或者异步方式。该插件采用GET方式。

https://github.com/zmofei/sysDate

 

posted @ 2014-07-08 13:41  梦1106  阅读(976)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3