强制 JObject 以“dd-mm-yyyy”格式进行序列化日期

本文关键字:序列化 日期 格式 JObject dd-mm-yyyy 强制 | 更新日期: 2023-09-27 18:24:55

public Guid AddJobs(JObject parametrs)
{
        dynamic jsonParameters = parametrs;
        JobViewModel job = jsonParameters.Job.ToObject<JobViewModel>();
}

以上是我的代码。我正在尝试使用上述方法反序列化此模型。问题是它不断给我例外,即日期格式不正确,因为它不期望"dd-mm-yyyy"。请帮帮我解决这个问题。

强制 JObject 以“dd-mm-yyyy”格式进行序列化日期

这里有两种方法:

1.直接在序列化程序上设置格式。它将在不正确的值上引发异常。

var jsonSer = new JsonSerializer();
jsonSer.DateFormatString = "dd-MM-yyyy";
JobViewModel job = obj.ToObject<JobViewModel>(jsonSer);

2.创建自定义转换器并处理不正确的值,无一例外:

public class CustomDateConverter : Newtonsoft.Json.Converters.DateTimeConverterBase
{
    private static readonly string DateTimeFormat = "dd-MM-yyyy";
    public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
    {
        DateTime res; // default value of a date is 01/01/0001
        // if parsing is successful that value will be changed, otherwise you get the default value and not and exception
        DateTime.TryParseExact(reader.Value.ToString(), DateTimeFormat, null, DateTimeStyles.None, out res); 
        return res;
    }
    public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
    {
        writer.WriteValue(((DateTime)value).ToString(DateTimeFormat));
    }
}

并将转换器添加到序列化程序:

var jsonSer = new JsonSerializer();
jsonSer.Converters.Add(new CustomDateConverter());
JobViewModel job = obj.ToObject<JobViewModel>(jsonSer);

这里有几件事可以尝试。

不知道这是否有效,但您可以尝试在模型的数据注释中设置 DisplayFormat 属性,并在其中指定日期格式。

根据您正在使用的 JSON 库,您可以探索它是否具有某种日期格式转换工具或某些设置,您可以在使用它时以编程方式执行。

同样不确定这一点,但您可以将该字段指定为 string,然后在反序列化后,将其转换为所需格式的日期时间。

由于您使用的是 Json.Net,请参阅他们的文档和他们的链接之一:点击这里

希望这有帮助。