php中Y2K38的漏洞解决方法实例分析
程序员文章站
2023-08-31 20:51:12
本文实例分析了php中y2k38漏洞的解决方法。分享给大家供大家参考。具体分析如下:
y2k38,又称 unix millennium bug, 此漏洞将会影响到所有 3...
本文实例分析了php中y2k38漏洞的解决方法。分享给大家供大家参考。具体分析如下:
y2k38,又称 unix millennium bug, 此漏洞将会影响到所有 32 位系统下用 unix 时间戳整数来记录时间的 php,及其它编程语言。
一个整型的变量所能保存的最大时间为 2038 年 1 月 19 日 03:14:07。超过这个时间后,整型数值将会溢出。
从 1970 年 01 月 01 日开始,到世界标准时 2038 年 01 月 19 日星期二凌晨 03:14:07 超过 2^31 – 1。2^31 – 1 就是 0x7fffffff,相信很多编程员都看过,在 32 位系统里,这表示最大的有符号整数。如果用它来表示秒数,大概相当于 68.1 年,从 1970 年到 2038 年刚好是这个数。
32位系统下显示2038年1月19日03:14:07以后的日期将会溢出。
<?php $date = '2040-01-01 12:00:00'; echo strtotime($date); // 空 溢出 echo date('y-m-d h:i:s', strtotime($date)); // 1970-01-01 00:00:00 ?>
那么64 位系统会受到影响吗?
理论上不会,强烈建议进行一下测试。64 位系统下可以保存的日期最远日期是现在宇宙年龄的 21 倍~ 292 亿年。
在32位机器上,可以使用datetime类来解决这个问题。(php5.2开始引入这个类,并在5.3版本中扩展了一些方法)
代码如下:
<?php $date = '2040-01-01 12:00:00'; $dt = new datetime($date); echo $dt->format('u'); // 2209032000 echo $dt->format('y-m-d h:i:s'); // 2040-01-01 12:00:00 ?>
希望本文所述对大家php程序设计的学习有所帮助。