JS 中获取服务器时间的注意点
在通过js获取服务器时间时,遇到了小小的问题,但造成的影响挺大的,所以写出来提醒大家,在获取服务器时间时一定要细心要多测试多验证。
js 中使用以下方法获取服务器时间时要注意两点:
1.xhr.open()方法中,中间的路径最好不要写 “” 或 "/",如果写空,在部分谷歌下获取时间会有问题,所以最好给一个具体的URL。
2.该获取时间方法,可以正确获取服务器时间,若服务器改时区后,此处获取的依然是服务器北京时区下应该显示的时间。
而本机电脑获取服务器时间后,也会将该时间转换为本机电脑上时区应该显示的问题。
所以本地改时区后,会将服务器时间改为本地时区对应的时间,这一点一定要注意!!!!!!!!!!!
可以将获取到的时间统一更改为北京时区时间,或直接改为从后台获取。
这两个方法也是从其他文章中摘抄的,希望大神能原谅~~~~~~~~~~~~~~~~~~~~
//获取服务器时间
function getServerDate(){
var xhr = null;
if(window.XMLHttpRequest){
xhr = new window.XMLHttpRequest();
}else{ // ie
xhr = new ActiveObject("Microsoft")
}
xhr.open("GET", "<%=basePath%>user/toupdpwd?id=26",false)//false不可变
xhr.send(null);
var date = xhr.getResponseHeader("Date");
//转为北京时区时间
//return getBeiJingTime(date)
return new Date(date);
}
//将时间转为北京时区时间
function getBeiJingTime(date) {
var d = new Date(date);
var timezone = 8; //目标时区时间,东八区
var offset_GMT = d.getTimezoneOffset(); // 本地时间和格林威治的时间差,单位为分钟
var nowDate = d.getTime(); // 本地时间距 1970 年 1 月 1 日午夜(GMT 时间)之间的毫秒数
var targetDate = new Date(nowDate + offset_GMT * 60 * 1000 + timezone * 60 * 60 * 1000);
console.log("东8区现在是:" + targetDate);
return targetDate;
}
————————————————
版权声明:本文为CSDN博主「yezi_huan」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/yezi_yanyuhuan/article/details/96769160
JavaScript获取当前时区:
new Date().getTimezoneOffset()
这样获取到的是与0时区的时间差(0时区减去当前所在时区,单位是分钟)
中国标准时间是以东八区为准,比0时区的时间要早8个小时,所以是-480,除以60就是所在时区
时间字符串转成毫秒时,如果我们不加时区,则系统会默认把当前时区加上,也可自定义时区来转换
(也可先转成毫秒,再加上时间差,再转成时间字符串,这样明显要麻烦多了)
————————————————
版权声明:本文为CSDN博主「password-u」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u013992330/article/details/78625855
第一种:
$.ajax({
type:"OPTIONS",
url:"/",
complete:function(x){
var date = x.getResponseHeader("Date");
date = new Date(date);
}
}); 结果:Mon Oct 23 2017 17:26:59 GMT+0800 (中国标准时间) 第二种:
function getNowDate(){
var xhr = null;
if(window.XMLHttpRequest){
xhr = new window.XMLHttpRequest();
}else{
xhr = new ActiveObject("Microsoft")
} xhr.open("GET","/",false);
xhr.send(null);
var date = xhr.getResponseHeader("Date");
date = new Date(date);
return date;
}
结果:Mon Oct 23 2017 17:26:59 GMT+0800 (中国标准时间)
原文地址:https://www.cnblogs.com/yexiaocangji/p/7717811.html
依赖jQuery
代码:
function getServerDate(){
return new Date($.ajax({async: false}).getResponseHeader("Date"));
}
JS 中获取服务器时间的注意点的更多相关文章
- js中获取当前时间
var d = new Date();var date = d.getFullYear() + "年" +(d.getMonth() + 1) + "月" + ...
- HTML 中获取现在时间,实时时间获取
JavaScript Date 对象 Date 对象用于处理日期与实际. 创建 Date 对象: var now = new Date(). 方法 描述 getDate() 从 Date 对象 ...
- JS中new Date()用法及获取服务器时间
1.获取服务器时间: var now = new Date($.ajax({async: false}).getResponseHeader("Date")); 2.new Dat ...
- JS实现Ajax---例:获取服务器时间
Ajax在本质上是一个浏览器端的技术 XMLHttpRequest XMLHttpRequest对象 XMLHttpRequest对象在IE浏览器和非IE浏览器中创建的方法不同. 简而言之:它可以异步 ...
- JS获取服务器时间并且计算距离当前指定时间差的函数
项目中遇到了从服务器获取时间,现在记录一下方便以后查询: 1.后台代码:(创建一个date对象并以JSON的形式返回去) // 获取服务器时间 public String getNowServerTi ...
- 小程序 js中获取时间new date()的用法(网络复制过来自用)
js中获取时间new date()的用法 获取时间: 1 var myDate = new Date();//获取系统当前时间 获取特定格式的时间: 1 myDate.getYear(); //获 ...
- Js中获取时间 new date()的用法
Js中获取时间 new date()的用法 获取时间: var myDate = new Date();//获取系统当前时间 myDate.getYear(); //获取当前年份(2位) myDate ...
- js中获得当前时间是年份和月份
js中获得当前时间是年份和月份,形如:201208 //获取完整的日期 var date=new Date; var year=date.getFullYear(); var month ...
- js中如何对时间进行设置
js中如何对时间进行设置 Js获取当前日期时间及其它操作var myDate = new Date();myDate.getYear(); //获取当前年份(2位)myDate.getF ...
随机推荐
- servlet获取checkbox的值出现选中的值为on。问题所在。。。
<form action="/Http/request06" method="post"> 用户名:<input type="tex ...
- Oracle定时调用存储过程
#1Demo: 1.创建表 create table job_table(run_time date); 2.创建存储过程 create or replace procedure job_proc i ...
- abstract class 与 interface
abstract class和interface是Java语言中对于抽象类定义进行支持的两种机制,正是由于这两种机制的存在,才赋予了Java强大的面向对象能力. abstract class和inte ...
- springboot加载application.yml文件null
话不多说,直接上代码 本人项目为maven项目 以下是项目结构 pom.xml文件 <?xml version="1.0" encoding="UTF-8" ...
- Python 变量作用域与函数
Python 的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承.Py ...
- HTML导航条的制作
导航条的制作HTML代码:<nav> <ul> <li> <a href="#"></a> </li> &l ...
- React会自动把虚拟DOM数组展开
React会自动把虚拟DOM数组展开,放在父级虚拟DOM中,这个特性还是我同事帮我解决一个问题的时候,偶然发现的. 如何将一个数据数组转换为一个虚拟DOM的数组,需要使用map,如下: const n ...
- fragment概念理解
fragment概念理解知识,fragment概念理解图片 fragment概念理解内容,fragment概念理介绍,fragment概念理正文 Fragment是Android honeycomb ...
- js获取图片内容上传
<script> $('#pic').change(function(){ var size=document.getElementById('pic').files[0].size va ...
- Dart 面向对象 类 方法
Dart是一门使用类和单继承的面向对象语言,所有的对象都是类的实例,并且所有的类都是Object的子类. 面向对象编程(OOP)的三个基本特征是:封装.继承.多态 封装:封装是对象和类概念的主要特性. ...