JavaScript or JQuery 获取服务器时间
Posted Jearay
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript or JQuery 获取服务器时间相关的知识,希望对你有一定的参考价值。
用js做时间校正,获取本机时间,是存在bug的。
使用js也可获取到服务器时间,原理是使用 ajax请求,返回的头部信息就含有服务器端的时间信息,获取到就可以了(有的IE下扔不会正常获取,还是更建议走后台接口的方式吧)。以下:
1、依赖jQuery
代码:
function getServerDate() { var serverDate; $.ajax({ async: false, type: "POST", success: function (result, status, xhr) { serverDate= new Date(xhr.getResponseHeader("Date")); }, error: function (result, status, xhr) { serverDate= new Date(); }, }); return serverDate; }
以上函数返回的就是一个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: 未找到页面
转自:https://www.cnblogs.com/hellobook/p/6112182.html
以上是关于JavaScript or JQuery 获取服务器时间的主要内容,如果未能解决你的问题,请参考以下文章
在 Javascript/JQuery 中从 REST Web 服务获取图像