微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net – NodaTime转换(第2部分).如何?

跟随我的第一篇文章

DateTime conversions using NodaTime on ASP.Net MVC 3 Razor website. How to?

我正在努力寻找一种简单的方式来转换本地和UTC之间的日期/时间(两种方式),使用NodaTime.

目前的图片是:

>我在数据库中保存了UTC的日期/时间.
>将它显示用户时,我应该考虑当地时区并相应地进行转换.
>当用户提供日期/时间作为过滤器时,我需要将其转换回UTC,然后再发送到SQL查询.

我到目前为止

扩展从UTC转换为本地(这部分工作正常):

public static DateTime UTCtoLocal(this DateTime dateTime)
    {
        IDateTimeZoneProvider timeZoneProvider = DateTimeZoneProviders.Tzdb;

        var utcTimeZone = timeZoneProvider["UTC"];
        var dateTimeFromDb = new DateTime(dateTime.Year,dateTime.Month,dateTime.Day,dateTime.Hour,dateTime.Minute,dateTime.Second,dateTime.Millisecond);

        var zonedDbDateTime = utcTimeZone.AtLeniently(LocalDateTime.FromDateTime(dateTimeFromDb));

        var usersTimezoneId = "Europe/London"; //just an example
        var usersTimezone = timeZoneProvider[usersTimezoneId];

        var userszoneddatetime = zonedDbDateTime.WithZone(usersTimezone);

        return userszoneddatetime.ToDateTimeUnspecified();
    }

扩展从本地返回到UTC(这部分是问题):

public static DateTime LocaltoUTC(this DateTime dateTime)
    {
        IDateTimeZoneProvider timeZoneProvider = DateTimeZoneProviders.Tzdb;
        var usersTimezoneId = "Europe/London";
        var usersTimezone = timeZoneProvider[usersTimezoneId];

        var dateTimeFromDb = new DateTime(dateTime.Year,dateTime.Millisecond);
        var zonedDbDateTime = usersTimezone.AtLeniently(LocalDateTime.FromDateTime(dateTimeFromDb));

        var utcTimezoneId = "UTC";
        var utcTimezone = timeZoneProvider[utcTimezoneId];

        var utczoneddatetime = zonedDbDateTime.WithZone(utcTimezone);

        return utczoneddatetime.ToDateTimeUtc();
    }

在这里做错了什么?

解决方法

你的UTCToLocal看起来像做的更多的工作比它需要,老实说.

应该是:

// Note: the DateTime here must have a "Kind" of Utc.
public static DateTime UTCtoLocal(this DateTime dateTime)
{
    Instant instant = Instant.FromDateTimeUtc(dateTime);
    IDateTimeZoneProvider timeZoneProvider = DateTimeZoneProviders.Tzdb;
    var usersTimezoneId = "Europe/London"; //just an example
    var usersTimezone = timeZoneProvider[usersTimezoneId];
    var userszoneddatetime = instant.InZone(usersTimezone);
    return userszoneddatetime.ToDateTimeUnspecified();
}

类似地,您的LocalToUTC应该是这些行:

// The DateTime here should have a "Kind" of Unspecified
public static DateTime LocaltoUTC(this DateTime dateTime)
{
    LocalDateTime localDateTime = LocalDateTime.FromDateTime(dateTime);

    IDateTimeZoneProvider timeZoneProvider = DateTimeZoneProviders.Tzdb;
    var usersTimezoneId = "Europe/London";
    var usersTimezone = timeZoneProvider[usersTimezoneId];

    var zonedDbDateTime = usersTimezone.AtLeniently(localDateTime);
    return zonedDbDateTime.ToDateTimeUtc();
}

你不需要将它转换成不同的时区:zoneddatetime知道这是什么,ToDateTimeUtc会做正确的事情.请注意,这里没有真正的dateTimeFromDb,因为如果您从未指定的DateTime转换,那可能来自用户

原文地址:https://www.jb51.cc/aspnet/250613.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐