这里有一些调试表达式,如果你不相信我,我会投入eclipse:
"strtotime("2110-07-16 10:07:47")" = (boolean) false
"strtotime("2110-07-16")" = (boolean) false
我在我的函数中使用它,它在开始日期和结束日期之间返回一个随机日期:
public static function randomDate($start_date, $end_date, $format = DateTimeHelper::DATE_FORMAT_SQL_DATE)
{
if($start_date instanceof DateTime) $start_date = $start_date->format(DateTimeHelper::DATE_FORMAT_YMDHMS);
if($end_date instanceof DateTime) $end_date = $end_date->format(DateTimeHelper::DATE_FORMAT_YMDHMS);
// Convert timetamps to millis
$min = strtotime($start_date);
$max = strtotime($end_date);
// Generate random number using above bounds
$val = rand($min, $max);
// Convert back to desired date format
return date($format, $val);
}
任何想法如何让它为未来的日期返回正确的unix时间?
谢谢!
答案 0 :(得分:12)
尝试在2038年1月19日星期二03:14:07 UTC之前保留它,当32位系统的unix时间戳纪元翻身时!
手册中对此进行了描述编辑刚测试:通过安装64位操作系统和适当的64位版本的php来修复它。我想我们有足够的时间修复一个转世的千禧虫:
$one = strtotime("9999-12-31 23:59:59");
$two = strtotime("10000-01-01 00:00:00");
var_dump($one);
var_dump($two);
int(253402297199)
bool(false)
答案 1 :(得分:12)
如果您想使用超出32位整数日期范围的日期,请使用PHP的dateTime对象
try {
$date = new DateTime('2110-07-16 10:07:47');
} catch (Exception $e) {
echo $e->getMessage();
exit(1);
}
echo $date->format('Y-m-d');
答案 2 :(得分:3)
时间戳的有效范围通常是从格林尼治标准时间1901年12月13日20:45:54到格林威治标准时间2038年1月19日星期二03:14:07。 (这些是与32位有符号整数的最小值和最大值对应的日期)。但是,在PHP 5.1.0之前,在某些系统(例如Windows)上,此范围仅限于01-01-1970至19-01-2038。
答案 3 :(得分:2)
您无法转换在修正时间翻转(2038)
之后发生的日期答案 4 :(得分:1)
简单替换strtotime
var number = "11 11";
console.log(format(number));
function format(number) {
if (number.length == 1 ) {
return '0' + number + ':00'
}else if (number.length == 2) {
return number + ':00'
} else if (number.length == 3){
return number.substring(0, 2) + ':' + number.substring(2)
} else if (number.length == 4 || number.length == 5){
return number.substring(0, 2) + ':' + number.substring(2).trim()
}
}
实际发布here。