2010-09-01 40 views
2

用户在表单中输入日期,但是当我通过AJAX json调用传递日期时,DataContractJsonSerializer会更改我的日期。DataContractJsonSerializer更改我的日期

这里是我的AJAX调用:

function Save() 
{ 
    //Convert date to milliseconds from from 1/1/1970 - necessary for passing a date through JSON 
    var d = "09/01/2010 05:00"; 
    myDate = new Date(d); 
    myTicks = myDate.getTime(); 

    var message = 
    { 
     MessageID: $("#MessageID").val(), 
     MessageDate: '\/Date(' + myTicks + ')\/', 
    }; 

    $.ajax({ 
     url: "<%= Url.Action("SaveMessage") %>", 
     type: "POST", 
     dataType: "json", 
     data: $.toJSON(message), 
     contentType: "application/json; charset=utf-8", 
     success: function(result) 
     { 
      if (result && result.success) 
      { 
       // 
      } 
     } 
    }); 
} 

这里是我的序列化代码:

public override void OnActionExecuting(ActionExecutingContext filterContext) 
{ 
    if ((filterContext.HttpContext.Request.ContentType ?? string.Empty).Contains("application/json")) 
    { 
     var serializer = new DataContractJsonSerializer(RootType); 

     filterContext.ActionParameters[Param] = serializer.ReadObject(filterContext.HttpContext.Request.InputStream); 
    } 
} 

它改变了我的日期GMT。因此,如果用户输入“09/01/2010 05:00”,系列化后它会显示为“09/01/2010 09:00”。

我能够通过使用下面的函数在我的本地环境中解决这个问题,但它在生产中不起作用。在我的本地环境中,服务器时间设置为EST(上午11:00)。在生产时,服务器时间设置为GMT(下午3:00)。

这里是我的转换功能:

public DateTime ConvertToLocal(DateTime dt) 
{ 
    int hours = TimeZoneInfo.Local.GetUtcOffset(dt).Hours; 

    DateTime dtGMT = dt.AddHours(Convert.ToDouble(hours)); 

    return dtGMT; 
} 

这会正确地从“09/01/2010 09:00 AM”改变我的可以追溯到“09/01/2010上午05点”在我当地的环境,但在生产上它保持“09/01/2010 09:00 AM”。

看起来在生产中,DataContractJsonSerializer意识到我正在浏览EST,所以它增加了4个小时。但由于我的生产服务器在格林尼治标准时间,我的ConvertToLocal不起作用,该函数中的时区偏移量为0而不是-4。

我能做些什么来解决这个问题?

回答

5

而不是使用myTicks = myDate.getTime();,你可能想使用myTicks = myDate.UTC();

的getTime()使用的是当地时间(基于在浏览器中运行的时区)。 UTC()也会为您提供1970年1月1日以来的毫秒数,但它是1970年1月1日UTC而不是当地时间。 Microsoft的JSON序列化日期使用UTC度量。

然后你不需要做任何服务器端转换。

+0

谢谢你,完美的作品。 – Steven 2010-09-01 17:32:06