js 获取服务器时间

这个方法是网上找到的: 

//获取服务器时间
function getServerTime(){
    return new Promise((resolve,reject)=>{
        var xhr = new XMLHttpRequest(); //XMLHttpRequest 对象用于在后台与服务器交换数据。
        if( !xhr ){
            xhr = new ActiveXObject("Microsoft.XMLHTTP");  //老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveX 对象
        }  
        xhr.open("HEAD", location.protocol + "//" +location.host, true);  //获取服务器的HEAD的请求
		//accept-ranges: bytes cache-control: no-cache,no-cache content-encoding: gzip content-length: 191 content-type: text/plain date: Mon, 11 May 2020 05:44:33 GMT etag: "b4f95099808cce1:0" last-modified: Mon, 29 Jul 2013 17:25:19 GMT server: Microsoft-IIS/10.0 status: 304 vary: Accept-Encoding x-powered-by: ASP.NET
        xhr.onreadystatechange=function(){  
            if( xhr.readyState == 4 && xhr.status == 200 ){
                resolve(xhr.getResponseHeader("Date"))
            }  
        }  
        xhr.send(null);
    })
}
//时间格式化
function dateTimeFormate(date){
  if(!date){
    return
  }else{
    var d = new Date(date);
    var year = d.getFullYear();
    var month = ('0' + (d.getMonth() + 1)).slice(-2);
    var day = ('0' + (d.getDate())).slice(-2);
    var hour = ('0' + (d.getHours())).slice(-2);
    var minutes = ('0' + (d.getMinutes())).slice(-2);
    var seconds = ('0' + (d.getSeconds())).slice(-2);
    return year + "-" + month + "-" + day + " " + hour + ":" + minutes + ":" + seconds;
  }
}

 

getServerTime().then( r=> {
	console.log(r);//得到的是美国时间

	let getServerTime = new Date(r);//转中国标准时间
	let serverTime = getServerTime.getTime();
	console.log(serverTime);//服务器时间戳

	let date = new Date(dateTimeFormate(r));//转日期格式 
	console.log(date);

	$.ajax({async:false}).getResponseHeader("Date");//同步请求响应头信息
	console.log($.ajax({async:false}).getResponseHeader("Date"));
});

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值