PHP中转换时间戳为可读字符串首选date()函数,需传入秒级整数时间戳并设置时区;DateTime类更安全,支持时区切换与异常捕获;毫秒级时间戳须先除以1000取整;三端时区须统一。

用 date() 函数转时间戳为可读字符串
PHP 中最直接、最常用的方式就是 date() 配合时间戳。它不修改原始时间戳,只按格式输出字符串,适合绝大多数展示场景。
-
date()第二个参数必须是整数型时间戳(秒级),不是毫秒;传入浮点数或字符串会静默失败或返回错误结果 - 第一个参数是格式字符串,比如
'Y-m-d H:i:s'输出2024-05-21 14:30:45 - 若省略第二个参数,
date()默认使用当前时间(time()),不是你传入的时间戳 - 时区影响结果:PHP 默认用系统时区,建议在脚本开头设好,例如
date_default_timezone_set('Asia/Shanghai');
date_default_timezone_set('Asia/Shanghai');
$timestamp = 1716298245;
echo date('Y-m-d H:i:s', $timestamp); // 输出:2024-05-21 14:30:45
用 DateTime 类做更安全的转换
当需要处理时区切换、加减日期、或时间戳来源不可信(如用户输入、数据库字段)时,DateTime 比 date() 更健壮。
- 构造时传入时间戳需加
@前缀,例如new DateTime('@1716298245');漏掉会当成日期字符串解析,结果完全错误 - 支持链式调用和时区动态切换:
$dt->setTimezone(new DateTimeZone('UTC')) - 对非法时间戳(如负数过大、非数字)会抛出
Exception,比date()的静默失败更容易定位问题
$timestamp = 1716298245;
$dt = new DateTime('@' . $timestamp);
$dt->setTimezone(new DateTimeZone('Asia/Shanghai'));
echo $dt->format('Y-m-d H:i:s'); // 同样输出:2024-05-21 14:30:45
注意毫秒级时间戳不能直接传给 date()
JavaScript 或某些 API 返回的是毫秒级时间戳(13 位),PHP 的 date() 和 DateTime 只接受秒级(10 位)。直接传会导致年份变成 50000+ 年。
- 正确做法是先除以 1000 并取整:
(int)($ms_timestamp / 1000) - 不要用
round()或floor()而不转整型——PHP 会把浮点数时间戳当作“1970-01-01 加上该秒数”,精度错乱 - 数据库里存的
BIGINT毫秒值,读出来后务必先转换再进date()
$ms_timestamp = 1716298245123;
$sec_timestamp = (int)($ms_timestamp / 1000);
echo date('Y-m-d H:i:s', $sec_timestamp); // 正确
从 MySQL 时间戳字段读取后怎么转
如果字段是 INT 或 BIGINT 存的 Unix 时间戳(秒或毫秒),PHP 读出来是字符串或整数,但可能因 PDO 设置或字段类型自动转成 float,导致精度丢失(尤其大数值)。
立即学习“PHP免费学习笔记(深入)”;
- 查之前确认字段类型:用
DESC table_name看是否为INT;如果是TIMESTAMP或DATETIME字段,MySQL 已帮你转成 'Y-m-d H:i:s' 字符串,无需再用date() - PDO 中设置
PDO::ATTR_STRINGIFY_FETCHES => false,避免整数被转成字符串再隐式转 float - 用
intval()强制转整,比直接用变量更安全,尤其对来自$_GET或 JSON 的数据
真正容易被忽略的是:时间戳本身不带时区信息,而你的 PHP、MySQL、前端三端时区不一致时,显示结果会差 8 小时甚至更多——别只盯着函数怎么写,先对齐时区。










