Konwersja Datetime.Now do UTC

Konwersja Datetime.Now do UTC
N0
  • Rejestracja:ponad 17 lat
  • Ostatnio:ponad 6 lat
  • Lokalizacja:Kraków
  • Postów:767
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:

Kopiuj
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 :/


Pomogłem? To dobrze :)
edytowany 1x, ostatnio: ne0
ŁF
Moderator
  • Rejestracja:ponad 22 lata
  • Ostatnio:około 8 godzin
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.


edytowany 2x, ostatnio: ŁF
N0
mi chodzi o samą konwersję już po stronie API, bo to że user mi local-a wysyła odpowiednio dla siebie to ja właśnie wiem. Chodzi mi jak z datetime zrobić UTC :)
ŁF
No właśnie ToUniversalTime załatwi - doda/odejmie godziny ze strefy czasowej i wyzeruje tę strefę. Ale jeśli czas od użytkownika przychodzi bez strefy czasowej, to trzeba się ciut bardziej pogimnastykować, bo skądś trzeba tę strefę czasową zdobyć.
BartoszSz
  • Rejestracja:około 11 lat
  • Ostatnio:ponad 6 lat
  • Postów:16
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ą.

N0
skoro jest w UTC to po co w ogóle patrzeć na konfigurację DB? Tak samo z informacją o strefie? Po co skoro po stronie usera to będzie konwertowane.
N0
  • Rejestracja:ponad 17 lat
  • Ostatnio:ponad 6 lat
  • Lokalizacja:Kraków
  • Postów:767
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.


Pomogłem? To dobrze :)
N0
  • Rejestracja:ponad 17 lat
  • Ostatnio:ponad 6 lat
  • Lokalizacja:Kraków
  • Postów:767
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! :)


Pomogłem? To dobrze :)
ŁF
Moderator
  • Rejestracja:ponad 22 lata
  • Ostatnio:około 8 godzin
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.


N0
  • Rejestracja:ponad 17 lat
  • Ostatnio:ponad 6 lat
  • Lokalizacja:Kraków
  • Postów:767
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ć?


Pomogłem? To dobrze :)

Zarejestruj się i dołącz do największej społeczności programistów w Polsce.

Otrzymaj wsparcie, dziel się wiedzą i rozwijaj swoje umiejętności z najlepszymi.