今天排查一个错误,在客户端(windows系统)给服务器(Unix系统)传送一组数据流时包含了一个DateTime类型的数据。保存后再从服务器上读出存储的时间,发现时间被提前了9个小时。
这个错误一度困惑了大家很久。今天是第二次着手这个任务。上次主要看了一下两端的代码,觉得都没有问题。(接口通信代码是看不到的)。今天主要研究了一下DateTime类型的属性。因为每次都是把时间提前9个小时,应该是属性设置的问题。
把整个DateTime的属性都仔细看了一遍,发现Kind属性很有可能导致这种问题。因为DateTime的kind有3个值local代表当地时间,utc代表了标准世界时间(协调通用时间),Unspecified表示既未指定为本地时间,也未指定为协调通用时间 (UTC)。日本正好位于东9,把时间转换为utc正好是提前了9个小时。。。然后判断了一下,将时间转换成本地时间,问题解决。问题最终原因归结为服务器与客户端通信协议中,使用的标准时间为utc时间。
在.net中有一个DateTimeKind 枚举类型量,里面成员为{Local,Unspecified,Utc},在判断或表示当前时间类型时可以使用。