PHP处理小程序毫秒时间戳需先除1000转为秒级,再用DateTime类显式指定时区(如Asia/Shanghai)格式化,避免date()函数的时区依赖和strtotime()对中文日期解析失败问题。
timestamp 是毫秒,PHP 默认按秒处理微信小程序调用 Date.now() 或 new Date().getTime() 得到的是毫秒级时间戳,而 PHP 的 date()、strtotime()、DateTime 等函数都只认秒级时间戳。直接传入会得到 1970 年左右的错误时间。
实操建议:
(int) 或 floor() 截断小数,避免浮点误差:(int) $timestamp / 1000
round() —— 毫秒值末尾是 500+ 时会进位,导致时间偏移 1 秒strlen($timestamp) === 13 ? (int)($timestamp / 1000) : (int)$timestamp
DateTime 类格式化比 date() 更安全
date() 依赖当前时区设置(date_default_timezone_set()),一旦漏设或设错,输出就偏;DateTime 可显式绑定时区,更适合多地区小程序用户。
实操建议:
$dt = new DateTime("@$seconds", new DateTimeZone('Asia/Shanghai'));
date('Y-m-d H:i:s', $seconds) 看似简单,但一旦服务器时区是 UTC,结果就是错的部分小程序 API(如云开发数据库写入、open-data 时间字段)要求标准 ISO 格式,例如 2025-05-20T14:30:00+08:00 或 2025-05-20T06:30:00Z(UTC)。PHP 的 date('c') 输出带时区偏移,但不等于 UTC;date('c', $ts) 仍受本地时区影响。
实操建议:
(new DateTime("@$seconds"))->setTimeZone(new DateTimeZone('UTC'))->format('Y-m-d\TH:i:s\Z')
(new DateTime("@$seconds"))->setTimeZone(new DateTimeZone('Asia/Shanghai'))->format('Y-m-d\TH:i:sO')(注意 O 输出 +0800,不是 +08:00;需手动替换可用 str_replace)ISO 8601 字符串(含时区)”,没写清楚时优先发带 +08:00 的strtotime() 对中文日期字符串解析不可靠小程序有时会把时间作为形如 "2025年5月20日 14:30" 的字符串传给后端。PHP 的 strtotime() 基本不支持中文语义解析,返回 false 或错误时间。
实操建议:
2025-05-20 14:30:00),后端不做中文容错preg_match('/(\d{4})年(\d{1,2})月(\d{1,2})日\s+(\d{1,2}):(\d{1,2})/', $str, $m),再拼成 "{$m[1]}-{$m[2]}-{$m[3]} {$m[4]}:{$m[5]}:00" 后丢给 strtotime()
DateTime 绑定 Asia/Shanghai → 按需 format() 输出。其他路径都容易在某个边缘 case 上翻车。