【发布时间】:2013-10-15 16:06:18
【问题描述】:
我目前正在努力确保我们的旧后端可以支持根据用户当前的时区(或者,更具体地说是偏移量)解析日期时间。我们的服务器采用东部标准时间,我们的大部分日期时间都来自那里。但是,对于处于其他时区的用户,在检索这些日期时间时需要转换到他们的时区(或者,在这种情况下,偏移量)。此外,来自用户的日期时间必须转换为东部标准时间,然后才能持久保存在服务器上。鉴于我们正在开发的前端是基于 Web 的,我能够在几分钟内检索到用户的偏移量,并将该值传递到我在标头中的服务层。我查看了 Noda Time 并认为它是一个很棒的 API。它确实迫使我在更精细的问题上思考时间,但我仍然不能 100% 确定我是否正确地使用了它。以下是我为上述转换编写的方法。我已经对它们进行了测试,它们似乎有效。鉴于上述情况,这看起来像是对库的正确使用吗?我是否正确考虑了日期时间?
public static DateTime ConvertToUtcFromEasternTimeZone(DateTime easternDateTime)
{
NodaTime.DateTimeZone easternTimeZone = NodaTime.DateTimeZoneProviders.Tzdb.GetZoneOrNull("America/New_York");
ZoneLocalMappingResolver customResolver = Resolvers.CreateMappingResolver(Resolvers.ReturnLater, Resolvers.ReturnStartOfIntervalAfter);
var easternLocalDateTime = LocalDateTime.FromDateTime(easternDateTime);
var easternZonedDateTime = easternTimeZone.ResolveLocal(easternLocalDateTime, customResolver);
return easternZonedDateTime.ToDateTimeUtc();
}
public static DateTime ConvertToEasternTimeZoneFromUtc(DateTime utcDateTime)
{
NodaTime.DateTimeZone easternTimeZone = NodaTime.DateTimeZoneProviders.Tzdb.GetZoneOrNull("America/New_York");
NodaTime.DateTimeZone utcTimeZone = NodaTime.DateTimeZoneProviders.Tzdb.GetZoneOrNull("UTC");
ZoneLocalMappingResolver customResolver = Resolvers.CreateMappingResolver(Resolvers.ReturnLater, Resolvers.ReturnStartOfIntervalAfter);
var utcLocal = LocalDateTime.FromDateTime(utcDateTime);
var utcZonedDateTime = utcTimeZone.ResolveLocal(utcLocal, customResolver);
var easternZonedDateTime = utcZonedDateTime.ToInstant().InZone(easternTimeZone);
return easternZonedDateTime.ToDateTimeUnspecified();
}
public static DateTime ConvertToUtc(DateTime dateTime, int offsetInMinutes)
{
LocalDateTime localDateTime = LocalDateTime.FromDateTime(dateTime);
var convertedDateTime = localDateTime.PlusMinutes(offsetInMinutes).ToDateTimeUnspecified();
return convertedDateTime;
}
public static DateTime ConvertFromUtc(DateTime dateTime, int offsetInMinutes)
{
LocalDateTime localDateTime = LocalDateTime.FromDateTime(dateTime);
var convertedDateTime = localDateTime.PlusMinutes(-offsetInMinutes).ToDateTimeUnspecified();
return convertedDateTime;
}
这里的想法是,当我在 UTC 时间和数据库中的时区之间进行解析时,时区很重要。当我在客户端时间和 UTC 时间之间进行解析时,偏移量很重要。
未来,我们可以坚持 UTC 时间,这会更容易。目前,这种解决方案只是权宜之计。
我们的想法是从...开始
客户端 -> UTC +/- 偏移量 -> UTC -> 东部时间 -> 数据库
数据库 -> 东部时间 -> UTC -> UTC +/- 偏移量 -> 客户端
到最后……
客户端 -> UTC +/- 偏移量 -> UTC -> 数据库
数据库 -> UTC -> UTC +/- 偏移量 -> 客户端
【问题讨论】:
-
当您说“我们的服务器采用东部标准时间”时,您实际上是指“我们的服务器采用东部标准时间”(美国东部标准时间和美国东部时间全年不同)吗?它有所作为。
-
是的,乔恩。感谢您的澄清。我确实需要考虑夏令时。
标签: c# datetime timezone timezone-offset nodatime