关于PHP转换超过2038年日期出错的问题解决
前言
最近在写一个项目接口。测试中发现服务器上测试正常的功能,在本地一直有问题。一步步的排查,最终锁定问题是由于函数strtotime
返回了一个false
值,导致数据插入数据库失败。
相同代码运行结果不一样,原因那就是环境不一致导致。要么是PHP版本不同,要么是位数不同。
我电脑是64位的。这里是PHP位数不一致,服务器使用64位,而我本地是32位。而strtotime
被传入了一个字符串2050-1-1 23:59:59
,该参数大于了2038-1-19 03:14:07
所以在32位PHP下直接返回false
,而64位PHP不受影响。
Y2K38漏洞
导致上述问题的根本原因就是Y2K38
漏洞,也被称为Unix Millennium Bug
。
32位系统或PHP
此漏洞将会影响到所有 32 位系统下用UNIX 时间戳整数来记录时间的 PHP,及其它编程语言。一个整型的变量所能保存的最大时间为 2038 年01月19 日 03:14:07
。超过这个时间后,整型数值将会溢出。
64位系统或PHP
64位系统下可以保存的日期最远日期是现在宇宙年龄的21倍——292亿年。所以不会受到该漏洞影响。
如何检测
如何知道你的系统是否收到该漏洞的影响。很简单,直接使用strtotime
去转换一个大于2038年1月19日03:14:07
日期。或者使用date函数将一个大于2147454847
时间戳转换为日期。
下面具体演示一下
方法一
echo date("Y-m-d H:i:s",2556115199); |
---|
上面结果如果返回2050-12-31 23:59:59那么就没有问题。如果返回1914-11-25 09:31:43那么就受收到影响。
方法二
var_dump(strtotime("2050-12-31 23:59:59")); |
---|
上面结果如果返回2556115199
那么就正常。如果返回false
那么也会受到影响。
解决方案
方案一
更换系统和PHP均为64位。这个代价比较大,但是可以永久解决问题。
方案二
PHP5.2版本之后提供了一个函数DateTime
可以临时解决一下问题。
// 1、日期字符串转换为时间戳 $obj = new DateTime("2050-12-31 23:59:59"); echo $obj->format("U"); // 2556115199 // 2、时间戳转换为日期字符串 $obj = new DateTime("@2556115199"); // 这里时间戳前要写一个@符号 $timezOne= timezone_open('Asia/HONG_KONG'); // 设置时区 $obj->setTimezone($timezone); echo $obj->format("Y-m-d H:i:s"); // 2050-12-31 23:59:59 // 而且DateTime还可以有其他玩法 $obj = new DateTime("2050-12-31 23:59:59"); echo $obj->format("Y/m/d H:i:s"); // 换种方式输入时间字符串2050/12/31 23:59:59 |
---|
通过DateTime
类来操作日期不会受到Y2K38
漏洞的影响,可以最远支持到9999年12月31日
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
未经允许不得转载:肥猫博客 » 关于PHP转换超过2038年日期出错的问题解决
相关文章
- php://input allow_url_include,php allow_url_include的应用和解释_PHP教程
- php时间戳,php时间代码合集,时间日期转换
- 学习MySQL还是PHP?(先学php还是mysql)
- 操作快速又简单:PHP进行MySQL数据库操作(php写mysql数据库)
- 环境管理 Linux下如何实现多版本PHP环境管理(linux多php版本)
- MySQL扩展:为PHP带来强大的数据库支持(php的mysql扩展)
- php日期格式转换详解编程语言
- PHP程序在Linux上的运行(php与linux)
- 扩展如何在PHP中开启Redis扩展(php开启redis)
- 利用PHP操作Redis变得更简单(php中redis的使用)
- 用PHP操作Oracle:实现强大的数据库能力(php支持oracle)
- 数据库解决PHP连接远程MySQL数据库的问题(php连接远程mysql)
- PHP Redis实时监控系统的应用(php redis 监控)
- PHP连接MSSQL:实现不同数据库的高效通信(php连接mssql端口)
- 从PHP到MSSQL:实现高效转换(php转换mssql)
- PHP实现MSSQL数据库分页功能(php分页类 mssql)
- 使用PHP和MSSQL搭建技术论坛(php mssql 论坛)
- PHP与MSSQL联合 处理日期数据(php mssql 日期)
- PHP实现稳定支持Redis的精彩瞬间(让php支持redis)
- MySQL版本问题无法支持PHP 53(mysql不支持5.3)
- 十天学会php(2)
- php&java(三)
- 《PHP边学边教》(02.Apache+PHP环境配置——上篇)
- IIS6的PHP最佳配置方法
- PHP中的MYSQL常用函数(php下操作数据库必备)
- PHP获取服务器端信息的方法
- PHP间隔一段时间执行代码的方法
- php使用sqlserver验证连接数据库的方法