在我的Web应用程序中,我让用户在简单的文本框中输入日期.那个输入(当然是在被消毒之后),通过strtotime()运行,并且向它添加86399,以使该时间戳记在当天结束时(11:59:59).这是截止日期(因此如果日期过去,应用程序会引发一个标志)
在我测试的那些日子里,它起作用了......
1月5日保存为1月5日,当天结束.
3月13日保存为3月13日
3月15日保存为3月15日
无论出于何种原因,3月14日将自己保存为3月15日.
3月14日是神秘的几秒钟还是什么?
更新:感谢oezi的解决方案 - 像魅力一样工作.所要求的代码:
旧代码:
if ($_POST['dateto'] != '') {
$dateto = strtotime(mysql_real_escape_string($_POST['dateto'])) + 86399;
}
Run Code Online (Sandbox Code Playgroud)
新代码:
# Offset to "end of day"
list($y,$m,$d) = explode('-',date("Y-m-d",strtotime($_POST['dateto'])));
$d++;
$dateto = strtotime($y . '-' . $m . '-' . $d) - 1;
Run Code Online (Sandbox Code Playgroud)
正如其他人所说,这是因为夏令时。为了解决这个问题,你可以这样做:
<?php
list($y,$m,$d) = explode('-',date("Y-m-d",strtotime($date_from_user)));
$h = 23;
$i = 59;
$s = 59;
$mytimestamp = "$y-$m-$d $h:$i:$s";
?>
Run Code Online (Sandbox Code Playgroud)