我正在研究“在线提醒系统”项目(ASP.NET 2.0(C#)/ SQL Server 2005)
因为这是一个提醒服务,它将在特定日期将邮件发送给用户。但是问题在于用户不是来自特定国家,而是来自世界各地和不同时区。现在,当我注册时,我要求用户的时区与Windows在安装时要求我们的时区相同。
但是我没有得到如果用户选择(+5.30)或某个时区,那么如何在我的asp.net应用程序中处理该时区。如何根据时区工作。
并请提出在此应用程序中是否有更好的方法来处理时区?
谢谢
第一件事是确保数据位于哪个时区。我建议确保将您存储的任何DateTime存储在UTC时间中(使用DateTime.ToUniversalTime()来保存它)。
DateTime.ToUniversalTime()
当要为用户存储提醒时,您将需要当前的UTC时间,添加或删除用户的时区差,然后将新时间转换回UTC。这就是您要存储在数据库中的内容。
然后,当您要检查要发送的提醒时,只需根据UTC时间在数据库中查找要立即发送的提醒;本质上是获得所有时间戳都在之前的提醒DateTime.Now.ToUniversalTime()。
DateTime.Now.ToUniversalTime()
更新 一些实现细节:您可以从TimeZoneInfo.GetSystemTimeZones()方法中获取时区列表;您可以使用这些时间显示用户的时区列表。如果Id从选定的时区存储属性,则可以从中创建一个TimeZoneInfo类实例,并为给定的本地日期/时间值计算UTC时间:
TimeZoneInfo.GetSystemTimeZones()
Id
TimeZoneInfo tzi = TimeZoneInfo.FindSystemTimeZoneById("<the time zone id>"); // May 7, 08:04:00 DateTime userDateTime = new DateTime(2009, 5, 7, 8, 4, 0); DateTime utcDateTime = userDateTime.Subtract(tzi.BaseUtcOffset);