js获取应用服务器时间,JavaScript获取服务器端时间的方法

js获取应用服务器时间,JavaScript获取服务器端时间的方法用 js 做时间校正 获取本机时间 是存在 bug 的 使用 js 也可获取到服务器时间 原理是使用 ajax 请求 返回的头部信息就含有服务器端的时间信息 获取到就可以了 以下 1 依赖 jQuery 代码 functiongetS returnnewDat ajax async false getResponseH Date 以上函数返回的就是一个 D

用js做时间校正,获取本机时间,是存在bug的。

使用js也可获取到服务器时间,原理是使用 ajax请求,返回的头部信息就含有服务器端的时间信息,获取到就可以了。以下:

1、依赖jQuery

代码:

function getServerDate(){

return new Date($.ajax({async: false}).getResponseHeader(“Date”));

}

以上函数返回的就是一个Date对象,注意在使用ajax时必须同步,要不然无法返回时间日期。

无需填写请求链接;

如果服务器时间和本地时间有时差,需要做校正。

2、原生

代码:

function getServerDate(){

var xhr = null;

if(window.XMLHttpRequest){

xhr = new window.XMLHttpRequest();

}else{ // ie

xhr = new ActiveObject(“Microsoft”)

}

xhr.open(“GET”,”/”,false)//false不可变

xhr.send(null);

var date = xhr.getResponseHeader(“Date”);

return new Date(date);

}

同样返回的是一个Date对象,xhr.open()必须使用同步;

无需填写请求链接;open,send,和getResponseHeader 必须按序编写。

如需使用异步请求,可监听onreadystatechange状态来做不同的操作。

代码如下:

function getServerDate(){

var xhr = null;

if(window.XMLHttpRequest){

xhr = new window.XMLHttpRequest();

}else{ // ie

xhr = new ActiveObject(“Microsoft”)

}

xhr.open(“GET”,”/”,true);

xhr.send(null);

xhr.onreadystatechange=function(){

var time,date;

if(xhr.readyState == 2){

time = xhr.getResponseHeader(“Date”);

date = new Date(time);

console.log(date);

}

}

}

使用异步不是很方便返回时间。

这里的readyState有四种状态,方便做不同处理:

0: 请求未初始化

1: 服务器连接已建立

2: 请求已接收

3: 请求处理中

4: 请求已完成,且响应已就绪

失败状态,status的值:

200: “OK”

404: 未找到页面

以上所述是小编给大家介绍的JavaScript获取服务器端时间的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/227810.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月16日 下午8:28
下一篇 2026年3月16日 下午8:29


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号