C# ConvertTimeFromUtc()和ToUniversalTime()是否处理DST?
如果夏令时生效,并且日期对象已保存到数据库中(UTC格式),您可以检索该数据库以在视图中显示它(例如C# ConvertTimeFromUtc()和ToUniversalTime()是否处理DST?,c#,timezone,dst,C#,Timezone,Dst,如果夏令时生效,并且日期对象已保存到数据库中(UTC格式),您可以检索该数据库以在视图中显示它(例如asp.net mvc中的视图) 您可以使用以下方法来实现: public static DateTime ConvertToLocalTimeFromUtcTime(DateTime utcDate, string timeZoneId) { TimeZoneInfo localZone = TimeZoneInfo.FindSystemTimeZoneById(timeZoneId);
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
将自动处理夏令时调整,只要目标时区使用夏令时
发件人:
执行转换时,ConvertTimeFromUtc
方法应用在destinationTimeZone
时区中有效的任何调整规则
您不应尝试在转换过程中再增加一小时。那会给你一个错误的翻译
关于
DateTime.ToUniversalTime
,它确实考虑了DST,但要小心使用此方法。它假定输入值位于计算机的本地时区。如果您只需要用DateTimeKind.Utc
标记它,那么请使用DateTime.SpecifyKind
。您的时区现在可能正在使用DST,这将使您的测试非常容易;)对DST是否在特定地区有效是当地的政治决定。在web服务器上,您对任何一个都不了解。总是在浏览器中进行转换,它知道。@AndrewMorton,没错,我确实看到从客户端提供的时间中减去了2小时。但反过来又如何呢?你是说我不必在服务器端转换用户所在区域的时间吗?也许这会很有用:。@HansPassant-在浏览器中转换不一定是最好的主意。这是一种方法,但是。如果您有时区id(OP在本例中就是这样做的),那么TimeZoneInfo
将比JavaScript更准确。此外,在很多情况下,您可能希望转换到不同的时区,而不仅仅是浏览器的本地时区。