PHP接收前端时间戳需先验判断毫秒/秒单位,用正则校验格式,显式转换并范围检查,再以new DateTime('@'.$ts)安全构造,统一约定秒级UTC可避免多数问题。
PHP 接收前端传的时间戳,本质就是接收一个整数(或字符串形式的数字),关键不在“怎么收”,而在“怎么判、怎么转、怎么防错”。前端传 timestamp 时常见格式混乱、时区错位、精度不一致,直接 date() 或 DateTime 构造极易出错。
JavaScript 的 Date.now() 返回毫秒级时间戳,而 PHP 的 time() 和大多数函数(如 strtotime()、DateTime::__construct())只接受秒级。若直接把 JS 时间戳丢给 date('Y-m-d', $ts),结果会是公元 50000+ 年。
strlen((string)$ts) === 13 → 很可能是毫秒;=== 10 → 更可能是秒$ts = (int) round($ts / 1000);(仅当确认是毫秒时才除)is_numeric():它会放过 "1623456789000abc" 这类脏数据preg_match('/^\d{10,13}$/', $ts),再结合长度决定是否除 1000$_GET['ts'] 或 $_POST['ts'] 拿到的是字符串,别直接当整数用PHP 的超全局变量中所有值默认是字符串,哪怕前端传 ts=1712345678,$_GET['ts'] 仍是字符串类型。某些函数(如 DateTime::createFromFormat('U', $ts))能自动 cast,但 date('Y-m-d', $_GET['ts']) 在严格模式下会触发 warning,且可能因隐式转换失败返回 false。
$ts = (int) $_GET['ts'];
if ($ts 2147483647) { /* 拒绝 */ }(注意:PHP 32 位系统 time_t 上限是 2147483647)filter_var() 更安全:$ts = filter_var($_GET['ts'], FILTER_VALIDATE_INT, ['options' => ['min_range' => 0, 'max_range' => 2147483647]]);
DateTime 处理时间戳比 date() 更健壮,但构造方式有坑date() 简单,但无法指定时区上下文;DateTime 支持时区、支持格式化、支持运算,但构造方式选错就白忙活。
new DateTime('@' . $ts) —— 注意 @ 前缀,这是告诉构造器“这是秒级时间戳”new DateTime($ts)—— 会尝试解析成 “1712345678” 这个日期,报错或返回意外结果
new DateTime('@' . $ts) 默认使用服务器时区,若需 UTC 结果,应:$dt = new DateTime('@' . $ts); $dt->setTimezone(new DateTimeZone('UTC'));DateTime::createFromFormat('U.u', floor($ms/1000) . '.' . sprintf('%06d', $ms % 1000)),但多数业务场景秒级足够与其在每个接口里反复判断毫秒/秒、反复 setTimeZone,不如在文档和规范层面定死:「所有时间戳字段均为秒级,时区为 UTC」。后端收到后直接 (int)$input['ts'] + new DateTime('@' . $ts) 即可,无歧义。
params: { ts: Math.floor(Date.now() / 1000) }
if (isset($data['start_time'])) { $data['start_time'] = validate_timestamp($data['start_time']); }
INT UNSIGNED 存秒级时间戳(兼容性好、排序快),而非 DATETIME(时区转换易出错)最常被忽略的不是“怎么转”,而是“谁负责校验”。前端传错、中间代理截断、N
ginx 重写规则吃掉参数……时间戳一错,后续所有格式化、比较、存储全崩。务必在最外层做类型+范围+单位三重校验,别信任何上游。
# php
# javascript
# java
# js
# 前端
# nginx
# axios
# 后端
# unix
# ios
# 隐式转换
相关文章:
宝塔Windows建站如何避免显示默认IIS页面?
制作表格网站有哪些,线上表格怎么弄?
招贴海报怎么做,什么是海报招贴?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
b2c电商网站制作流程,b2c水平综合的电商平台?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
如何续费美橙建站之星域名及服务?
成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
零基础网站服务器架设实战:轻量应用与域名解析配置指南
Swift中switch语句区间和元组模式匹配
制作旅游网站html,怎样注册旅游网站?
制作证书网站有哪些,全国城建培训中心证书查询官网?
如何在IIS中新建站点并解决端口绑定冲突?
建站之星如何防范黑客攻击与数据泄露?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
如何配置IIS站点权限与局域网访问?
网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?
广德云建站网站建设方案与建站流程优化指南
如何在IIS中新建站点并配置端口与IP地址?
建站之星免费版是否永久可用?
seo网站制作优化,网站SEO优化步骤有哪些?
湖北网站制作公司有哪些,湖北清能集团官网?
,制作一个手机app网站要多少钱?
Python如何创建带属性的XML节点
公众号网站制作网页,微信公众号怎么制作?
深圳网站制作培训,深圳哪些招聘网站比较好?
深圳网站制作的公司有哪些,dido官方网站?
平台云上自主建站:模板化设计与智能工具打造高效网站
如何通过主机屋免费建站教程十分钟搭建网站?
建站主机类型有哪些?如何正确选型
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
建站ABC备案流程中有哪些关键注意事项?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
历史网站制作软件,华为如何找回被删除的网站?
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
如何快速上传建站程序避免常见错误?
如何挑选优质建站一级代理提升网站排名?
小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化
IOS倒计时设置UIButton标题title的抖动问题
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
北京制作网站的公司,北京铁路集团官方网站?
如何用好域名打造高点击率的自主建站?
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
css网站制作参考文献有哪些,易聊怎么注册?
建站之星备案是否影响网站上线时间?
昆明高端网站制作公司,昆明公租房申请网上登录入口?
如何构建满足综合性能需求的优质建站方案?
*请认真填写需求信息,我们会在24小时内与您取得联系。