Konwersja Datetime.Now do UTC

0

Hej,

w bazie danych trzymana będzie pogoda na daną chwilę oraz na przyszłość. Daty i godziny chcę trzymać w formacie UTC - tak aby dopiero po stronie aplikacji mobilnej dochodziło do odpowiedniej konwersji. I teraz mam pewien problem z robieniem tej konwersji:

weather.DateTimeCreated = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Utc);

Na chwilę pisania tego posta, DateTime.Now pokazuje 15:45 (dla polski), natomiast DateTimeCreated w moim rozumowaniu powinien pokazywać 13:45 - jednakże pokazuje to samo.

Ma ktoś może jakiś pomysł dlaczego tak się dzieje i jak konwertować czas do UTC?

Mogę użyć jeszcze DateTime.Now.ToUniversalTime ale też gdzieś czytałem że to nie zawsze będzie UTC :/

1

ToUniversalTime/ToLocalTime
Od użytkownika przychodzi data lokalna, konwertujesz ją na UTC i zapisujesz, potem przy wyświetlaniu robisz ToLocalTime. No rocket science, chociaż łatwo się pomylić i gdzieś o tej podwójnej konwersji zapomnieć.

BTW DateTime.UtcNow.

1

W .NET od wersji 3.5 jest wbudowany mechanizm, który pozwala zająć się takimi tematami. Istnieje klasa TimeZoneInfo, która posiada metodę ConvertTime, która dokonuje odpowiedniej konwersji. Rzuć okiem do dokumentacji, wszelkie przekształcenia zrobi za Ciebie. Przy systemach globalnych warto trzymać w bazie dane w jednym konkretnym formacie oraz informacje o strefie, aby być w stanie to pożenić później w aplikacji. Twój pomysł generalnie z UTC jest dobry. Warto też zerknąć do konfiguracji bazy i uzgodnić domyślną strefę czasową.

0
ŁF napisał(a):

ToUniversalTime/ToLocalTime
Od użytkownika przychodzi data lokalna, konwertujesz ją na UTC i zapisujesz, potem przy wyświetlaniu robisz ToLocalTime. No rocket science, chociaż łatwo się pomylić i gdzieś o tej podwójnej konwersji zapomnieć.

BTW DateTime.UtcNow.

Tutaj faktycznie działa mi ToUniversalTime i tak właśnie robię obecnie, czyli to jest dobre rozwiązanie.

Co do DateTime.UtcNow to też jest OK ale on działa na podstawie obecnej chwili - czyli nie podam mu parametru typu DateTime bądź nie wywołam go na DateTime statycznie.

0
BartoszSz napisał(a):

W .NET od wersji 3.5 jest wbudowany mechanizm, który pozwala zająć się takimi tematami. Istnieje klasa TimeZoneInfo, która posiada metodę ConvertTime, która dokonuje odpowiedniej konwersji. Rzuć okiem do dokumentacji, wszelkie przekształcenia zrobi za Ciebie. Przy systemach globalnych warto trzymać w bazie dane w jednym konkretnym formacie oraz informacje o strefie, aby być w stanie to pożenić później w aplikacji. Twój pomysł generalnie z UTC jest dobry. Warto też zerknąć do konfiguracji bazy i uzgodnić domyślną strefę czasową.

TimeZoneInfo - nie wiedziałem że coś takiego jest, fajna sprawa i fajnie też działa; dzięki! :)

2
ne0 napisał(a):

Co do DateTime.UtcNow to też jest OK ale on działa na podstawie obecnej chwili - czyli nie podam mu parametru typu DateTime bądź nie wywołam go na DateTime statycznie.

Na pewno da się użyć wszędzie tam, gdzie DateTime.Now. Na przykład zamiast całej kombinacji alpejskiej DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Utc).
Swoja drogą jeśli robisz projekt, który ma szansę kiedyś trochę urosnąć, to opakuj wszystkie operacje na czasie w jakiś serwis i interfejs, potem będzie Ci łatwiej zrobić IoC/DI i pokrycie testami.

0

Jak to zrobić?
Nie będę pisał dokładnie co robi moja apka, ale mam tam kilka miejsc gdzie są operacje na czasie:

  1. Pogoda (pobieram z API pogode aktualną dla danej lokalizacji usera oraz schedule na najbliższe np. 5 dni)
  2. Dostępność "tego czego nie zdradzę" gdzie też odpytuje zewnętrzne API (pogoda też zewnętrzne) i mam tam zaszyty czas w UTC.

Potem przychodzi request od usera i w zależności czy mam już w bazie danych pogode to albo ją wyświetlam (pobieram z DB) albo pobieram z API, zapisuje do DB i wyświetlam userowi -> tak samo w tym drugim przypadku.

Obecnie mam takie 2 serwisy: WeatherService oraz "ToCos"Service -> oba dokonują wszystkich operacji (z bazą danych łączą się za pomocą repozytorium).

Czyli jakby taki serwis do samego czasu miał by wyglądać i gdzie to umieścić?

1 użytkowników online, w tym zalogowanych: 0, gości: 1