ConvertTimeFromUtc()和ToUniversalTime()是否处理DST?
如果夏令时生效,并且日期对象已保存到数据库中(UTC格式),您将检索该数据库以在视图中显示它(例如asp.net-mvc
的视图)。
你通过使用这种方法来做到这一点:
public static DateTime ConvertToLocalTimeFromUtcTime(DateTime utcDate, string timeZoneId) { TimeZoneInfo localZone = TimeZoneInfo.FindSystemTimeZoneById(timeZoneId); DateTime localTime = TimeZoneInfo.ConvertTimeFromUtc(utcDate, localZone); if (localZone.IsDaylightSavingTime(localTime)) localTime = localTime.AddHours(1); // is this needed !? return localTime; }
问题是, TimeZoneInfo.ConvertTimeFromUtc()
处理DST,或者您是否必须自己检查并向日期对象添加或减去X小时?
通过使用ToUniversalTime()
将日期对象转换为UTC格式来将日期对象持久化到数据库时的相同问题。
是。 只要您定位的时区使用夏令时, ConvertTimeFromUtc
就会自动处理夏令时调整。
从MSDN文档 :
执行转换时,
ConvertTimeFromUtc
方法应用destinationTimeZone
时区中有效的任何调整规则。
您不应该尝试在转换中添加额外的小时。 这会给你一个不正确的翻译。
关于DateTime.ToUniversalTime
,它确实考虑了DST,但要小心这个方法。 它假定输入值在计算机的本地时区。 如果您只需要使用DateTime.SpecifyKind
标记它,那么请改用DateTime.SpecifyKind
。