我们之前的开发人员创建了一个通用方法,用于检索具有更新/更改的所有用户输入。 它看起来像这样(用户端/ JavaScript / Kendo):
param._updated = JSON.stringify(rows._updated);
我有点绝望,当* rows._updated包含日期值叔叔JSON将其转换为其他String格式,导致 DateTime 差异例如:
dateField = 11/1/2015 // <--Original User Input
rows._updated = { dateField: November 1, 2015 0:00:00 GMT+080 ... }
param._updated = { "dateField": "2015-10-31T16:00:00.0000Z"... }
现在会导致冲突。 由于上面的代码是可能包含不同数据和类型的通用字段,我试图在服务器端解决这个问题,但我没有达到原始日期值。
注意:我们的用户有2-5个不同的时区,因此很难对转换进行硬编码。 相关问题:here
现在已经很晚了。提前致谢!。
答案 0 :(得分:0)
我通过以下方法实现了我想要的目标
1。)在后端将DateTime转换为UTC格式
string dateUTC = paramDate.ToString("yyyy'-'MM'-'dd'T'HH':'mm':'ss'.'fff'Z'");
2。)现在我已经创建了一个方法来处理UTC Date转换为PlainDate
public static string UTCtoPlainDate(string dateUTC)
{
if (string.IsNullOrEmpty(dateUTC)) return "";
DateTime dateTime;
// Assume date in UTC format, e.g. '2015-03-31T12:00:00.000Z'
DateTime.TryParseExact(dateUTC, "yyyy-MM-dd'T'HH:mm:ss.fff'Z'", System.Globalization.CultureInfo.InvariantCulture,
System.Globalization.DateTimeStyles.AssumeUniversal, out dateTime);
return dateTime.ToString("yyyy-MM-dd") ?? "";
}