用户在表单中输入日期,但是当我通过AJAX json调用传递日期时,我的日期会被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)
{
//
}
}
});
}
Run Code Online (Sandbox Code Playgroud)
这是我的序列化代码:
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);
}
}
Run Code Online (Sandbox Code Playgroud)
它将我的约会时间改为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;
}
Run Code Online (Sandbox Code Playgroud)
这将在我的本地环境中正确地将我的日期从"09/01/2010 09:00 AM"更改回"09/01/2010 05:00 AM",但在生产时它保持为"09/01/2010 09: 00 AM".
看起来在生产中,DataContractJsonSerializer意识到我正在浏览EST,所以它增加了4个小时.但由于我的生产服务器是GMT,我的ConvertToLocal不起作用,该函数中的时区偏移量为0而不是-4.
我该怎么做才能解决这个问题?
而不是使用myTicks = myDate.getTime();你可能想要使用myTicks = myDate.UTC();
getTime()使用本地时间(基于浏览器运行的时区).UTC()也给你自1970年1月1日以来的毫秒数,但它是1970年1月1日UTC而不是当地时间.Microsoft的JSON序列化日期使用UTC度量.
然后,您不需要进行任何服务器端转换.
| 归档时间: |
|
| 查看次数: |
1081 次 |
| 最近记录: |