gpt4 book ai didi

php - Javascript 日期对象未正确调整时区偏移

转载 作者:可可西里 更新时间:2023-11-01 07:45:29 24 4
gpt4 key购买 nike

我在一个事件网站上工作。我从本地主机上的 MySQL 数据库获取 UTC 时间,并使用 PHP 将它们回显到页面,然后使用 Javascript 将它们转换为用户的时区。出于某种原因,Javascript 给我的时间比我从 MySQL 得到的时间晚了两个小时。我和我的服务器都在山地标准时区,所以 Javascript 应该将日期推迟 6 小时,但日期却推迟了 8 小时。即使是夏令时也只占一小时的时差,而不是两小时。

这是将 PHP 时间戳转换为日期对象并以 YYYY-mm-dd HH:ii:ss 格式输出的 Javascript(使用 jQuery):

function leadingzeros(string){
if (string.toString().length == 1){
string = "0" + string;
}
return string;
}

$(document).ready(function(){
var thisdate = new Date(<?php echo (strtotime($row['start'])*1000);?>);
$("#jsdate").html(
thisdate.getFullYear()+"-"+leadingzeros((thisdate.getMonth()+1))+"-"+ leadingzeros(thisdate.getDate())+" "+
leadingzeros(thisdate.getHours())+":"+leadingzeros(thisdate.getMinutes())+":"+leadingzeros(thisdate.getSeconds())
);
});

这是文档正文的 PHP:

<?php
$row = mysqli_fetch_assoc($result);
echo "<ul><li>MySQL datetime object: ".$row['start']."</li>".
"<li>PHP Unix timestamp: ".strtotime($row['start'])."</li>".
"<li>PHP date string: ".date("Y-m-d H:i:s",strtotime($row['start']))."</li>".
"<li>PHP date minus 6 hours (which is our timezone offset): ".date("Y-m-d H:i:s",strtotime($row['start']) - (6*3600))."</li>".
"<li>Javascript date: <span id='jsdate'></span></li></ul>";
?>

输出:

  • MySQL 日期时间对象:2012-04-07 23:00:00
  • PHP Unix 时间戳:1333832400
  • PHP 日期字符串:2012-04-07 23:00:00
  • PHP 日期减去 6 小时(这是我们的时区偏移量):2012-04-07 17:00:00
  • Javascript 日期:2012-04-07 15:00:00

我阅读的所有文档都没有给出答案。为什么 Javascript 日期在 MST 中比 PHP 日期晚两个小时?

最佳答案

之所以会出现这种情况是因为 strtotime() 在解析给定日期/时间时默认使用 date.timezone 设置,因此结果得到相应的补偿.

要解决此问题,您可以将 date.timezone 设置为 Etc/UTC 或“锚定”数据库中的时间戳,如下所示:

strtotime("{$row['start']} GMT")

关于php - Javascript 日期对象未正确调整时区偏移,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10057347/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com