ASP.NET MVC5 以错误的格式存储日期

ASP.NET MVC5 stores date in wrong format

最后几天我很难说服 MVC5 项目按照我的意愿处理日期。经过密集的谷歌搜索后,我尝试了无数次尝试使其正常工作,但没有成功。

问题是:

我需要在我的网页上以 dd.MM.yyyy 格式显示和编辑日期(即 15.07.2015)。对于编辑,我还需要使用 jquery ui 日期选择器。这里的事情是我已经能够成功地将日期选择器设置为以请求的格式显示日期,而且 jquery 验证现在可以正确地验证给定格式的日期。至于 UI 到目前为止还不错。问题立即出现,当我单击提交按钮时 - 出现一条错误消息,如:

值“15.07.2015”对于开始日期无效。

经过简短的调查,我发现当日期被传递到服务器时,它已经转换了格式——而不是 dd.MM.yyyy,日期被处理为 MM.dd.yyyy。换句话说,仅当日期的日期部分高于 12 时才会弹出错误。

以下是我的代码中的一些亮点:

在我的日期模型中,我有这个:

[Required]
[Display(Name = "Start Date")]
[DataType(DataType.Date)]
[UIHint("Date")]
[DisplayFormat(DataFormatString = "{0:dd.MM.yyyy}", ApplyFormatInEditMode = true)]
public DateTime DateStarts;

我认为我需要做的就是以指定格式显示日期,并强制用户以正确的格式在文本框中填写日期。

如 [UIHint("Date")] 中所述,我有自己的模板来呈现用于编辑日期的文本框。该模板的实现如下:

@model Nullable<DateTime>

@{

DateTime dt = DateTime.Now;

if (Model != null)
{
    dt = (System.DateTime)Model;
}

@Html.TextBox("", dt.ToString("dd.MM.yyyy"), new { @class = "form-control datecontrol", type = "text", data_val_date = "Field must have format dd.MM.yyyy" })
<i class="fa fa-calendar form-control-feedback lowerzindex"></i>

}

jquery 日期选择器有以下实现:

 $('.datecontrol').datepicker({
    onClose: function () { $(this).valid(); },
    minDate: "-1M",
    dateFormat: "dd.mm.yy",
});

所以即使是日期选择器也知道格式应该是什么样子。

最后一个组成部分是 jquery.validation 的验证:

 $.validator.addMethod(
    'date',
    function (value, element, params) {
        if (this.optional(element)) {
            return true;
        };
        var result = false;
        try {
            $.datepicker.parseDate('dd.mm.yy', value);
            result = true;
        } catch (err) {
            result = false;
        }
        return result;
    },
    ''
);

我知道日期以某种文化中性格式传递到服务器,但我认为当我用请求的格式在许多地方修饰代码时,这将确保转换为该文化中性格式。正确的。还是我漏掉了什么?

谢谢

您的问题在于您没有为您的应用程序设置正确的 Culture。您的请求最终在具有 month-day-year 顺序的文化下执行(可能在 en-US 下)给您带来了问题。

最简单的解决方案是在 web.config 中设置实际具有 day-month-year 顺序和 . 的文化作为日期分隔符,例如:

<configuration>
   <system.web>
       <globalization uiCulture="de-DE" culture="de-DE" />
       ...

https://msdn.microsoft.com/en-us/library/bz9tc508%28v=vs.140%29.aspx

MVC 在解析发布的数据并将其绑定到您的 models/parameters 时使用当前区域性。 建议在整个范围内使用相同的日期分隔符 - html、客户端、javascript、服务器文化、...