NTP 2036年2月6号时间溢出导致的无法正常更新时间问题解决方法
- 原因:
NTP协议的时间戳采用了和Unix类似的32位整数表示,但不同Unix的1970+68年的时间范围,NTP使用的是无符号整型,并且以1900年作为时间的起点,这样意味着它的时间终点将会是1900+136 = 2036年2月6日。超出这个时间,将会导致时间获取异常而无法更新时间。
- 解决办法:
在请求NTP服务器之前对当前时间进行校验,如果时间范围大于2036-2-6,则给一个正确的时间点。
/frameworks/base/core/java/android/net/SntpClient.java
/**
* Reads the NTP time stamp at the given offset in the buffer and returns
* it as a system time (milliseconds since January 1, 1970).
*/
private long readTimeStamp(byte[] buffer, int offset) {
long seconds = read32(buffer, offset);
long fraction = read32(buffer, seconds offset + 4);
// Special case: zero means zero.
if (seconds == 0 && fraction == 0) {
return 0;
}
//对时间添加判断,超出最大时间就先给一个初始值
if(seconds < OFFSET_1900_TO_1970){
Log.d(TAG,"time overflow);
seconds += 0x100000000L;
}
return ((seconds - OFFSET_1900_TO_1970) * 1000) + ((fraction * 1000L) / 0x100000000L);
}