NTP 2036年2月6号时间溢出导致的无法正常更新时间问题解决方法

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);
    }
  • 参考:https://blog.csdn.net/rjdeng/article/details/48623949

你可能感兴趣的:(Android,Framework,ntp,2036,android)