0
点赞
收藏
分享

微信扫一扫

关于iphone手机中sms.db文件中日期的解读

外贸达人小峻先森 2022-02-18 阅读 114
ios

最近稍微研究了下iPhone的短信文件sms.db(怎么获取这个网上有不少教程,自己iPhone的系统是IOS 14.7.1)。sms.db可以用SQLite打开。打开后能读取短信内容,但发现时间不是人可读的时间。

网上搜了下,也没发现个直接的答案。但网上还是给了不少提示。

1. 这应该是个时间戳

2.苹果是从2001年1月1日开始算时间戳的,并非一般从1970年开始计算。也就是说这个时间戳是指从2001年1月1日开始经过的秒数。

尝试算了下从2001年1月1日0点至2022年2月17日0点的秒数:7717天*24小时*60*分*60秒=666748800

算出的数据开头和sms.db里面的data的开头都是66,那思路是对了,但位数不一样。一开始想了下,秒的下面几位是毫秒、微米、纳秒、皮秒,且都是1000进位。

如果加上纳秒位数的话 7717天*24小时*60*分*60秒*1000毫秒*1000微妙*1000*纳秒=666748800000000000,这下位数对了。但其实后面的毫秒等单位我不需要知道。

由此可以计算时间了。

 

 这个时间是对的,但日期不对呀。哦,原因是苹果的时间计算点是2001年1月1日0点,一般的计算开始时间点是1970年1月1日0点。两者相差的秒数是978307200秒,加上就行了。

 至此问题解决。

举报

相关推荐

0 条评论