strtotime() 返回 false 的主因是输入格式不匹配其默认模糊规则,如纯数字日期、中文日期、自定义分隔符或时区标识不被识别;应优先用 DateTime::createFromFormat() 精确解析并严格校验。
strtotime() 返回 false 通常不是函数坏了,而是输入字符串不符合它默认接受的模糊格式。它不支持纯数字日期(如 "20250101")、带空格的中文日期(如 "2025年1月1日")、或自定义分隔符未被识别(如 "2025-01-01T12:00:00" 中的 T 在旧 PHP 版本中可能被忽略但不报错,实际解析结果却错)。
"Jan")在非 C locale 下可能失效"2025-02-30" 会被静默转为 2025-03-02,而非 false
当字符串格式固定(比如来自表单、API 或日志),优先用 DateTime::createFromFormat(),它要求格式与字符串严格匹配,失败才返回 false,便于定位问题。
date_default_timezone_set('Asia/Shanghai');
$d = DateTime::createFromFormat('Y-m-d H:i:s', '2025-12-25 14:30:00');
if (!$d || $d->format('Y-m-d H:i:s') === false) {
// 解析失败,可明确知道是格式不匹配
}
'Y-m-d' 不匹配 "2025/12/25",得改用 'Y/m/d'
! 重置时间(如 '!Y-m-d' 会把时分秒设为 00:00:00)DateTime::getLastErrors() 能拿到具体哪一位不匹配PHP 5.4+ 开始支持 ISO 8601 扩展格

"2025-01-01T12:00:00+08:00"),但 PHP 5.2 会直接失败。若需兼容老环境,别依赖 strtotime() 自动识别带时区的字符串。
"2025-01-01 12:00:00 UTC" 在 PHP 7.0+ 可解析,5.6 可能失败"2025-01-01 12:00:00 GMT+8" 多数版本都不认,应统一转成 +08:00 格式date_parse_from_format() 预检格式合法性,比直接构造 DateTime 更轻量别把 strtotime() 结果直接当布尔判断——它成功时返回时间戳(整型),而 0 对应的是 1970-01-01 00:00:00 UTC,在 if 中会被当成 false,造成误判。
$ts = strtotime('1970-01-01 00:00:00');
if ($ts === false) { // ✅ 正确:用全等判断
echo "解析失败";
} else {
echo date('Y-m-d', $ts); // 输出 1970-01-01
}
=== false 判断失败,不用 == false 或 !$ts
null、含非法字符的字符串,strtotime() 统一返回 false
strtotime(),既没预处理也没做失败兜底,结果线上某天突然某个时区/格式的数据让整个订单时间逻辑崩掉。