目录
一、Newtonsoft.Json下自定义DateTime序列化格式器
1. 定义DateFormatConverter
2. 在实体上使用自定义的DateFormatConverter特性
二、System.Text.Json下自定义DateTime的序列化格式器
1. 定义DateTimeConverter
2. 定义DateTimeJsonConverter特性
3. 在实体上使用自定义的DateTimeJsonConverter特性
本文介绍了Newtonsoft.Json与System.Text.Json下如何在实体上自定义DateTime类型的序列化格式。
一、Newtonsoft.Json下自定义DateTime序列化格式器
1. 定义DateFormatConverter
using Newtonsoft.Json.Converters;namespace HZCC.Test.Model.Converter
{/// <summary>/// 日期格式转换器/// </summary>/// <remarks>/// 使用方法:在实体属性上指定序列化时需要的日期时间格式/// </remarks>public class DateFormatConverter : IsoDateTimeConverter{/// <summary>/// 构造函数/// </summary>/// <param name="format"></param>public DateFormatConverter(string format){DateTimeFormat = format;}}
}
2. 在实体上使用自定义的DateFormatConverter特性
using HZCC.Test.Model.Converter;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace HZCC.Test.Model.Input
{/// <summary>/// 出差数据/// </summary>public class CcLeaveDto{/// <summary>/// id/// </summary>public string Id { get; set; }/// <summary>/// 姓名/// </summary>public string Name { get; set; }/// <summary>/// 出差开始日期/// </summary>[JsonConverter(typeof(DateFormatConverter), "yyyy-MM-dd HH:mm:ss.fff")]public DateTime ActualStartTime { get; set; }/// <summary>/// 出差结束日期/// </summary>[JsonConverter(typeof(DateFormatConverter), "yyyy-MM-dd HH:mm:ss.fff")]public DateTime ActualEndTime { get; set; }}
}
二、System.Text.Json下自定义DateTime的序列化格式器
适用于System.Text.Json的自定义DateTime序列化转换器,可在Model属性上指定具体序列化格式
1. 定义DateTimeConverter
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Linq;
using System.Text;
using System.Text.Json;
using System.Threading.Tasks;namespace HZCC.Test.Model.Converter
{/// <summary>/// 适用于System.Text.Json的DateTime格式转换器,可指定日期格式/// </summary>/// <param name="format">日期格式,示例:yyyy-MM-dd、yyyy-MM-dd HH:mm:ss、yyyy-MM-dd HH:mm:ss.fff</param>public class DateTimeConverter(string format) : System.Text.Json.Serialization.JsonConverter<DateTime>{private readonly string _format = format;/// <summary>/// 读取/// </summary>public override DateTime Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options){if (reader.GetString()! == null) return DateTime.MinValue;return DateTime.ParseExact(reader.GetString()!, _format, CultureInfo.InvariantCulture);}/// <summary>/// 写入/// </summary>public override void Write(Utf8JsonWriter writer, DateTime dateTimeValue, JsonSerializerOptions options){writer.WriteStringValue(dateTimeValue.ToString(_format, CultureInfo.InvariantCulture));}}
}
2. 定义DateTimeJsonConverter特性
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Text;
using System.Text.Json.Serialization;
using System.Threading.Tasks;namespace HZCC.Test.Model.Converter
{/// <summary>/// 适用于System.Text.Json的DateTime格式转换器特性,可指定日期格式/// 使用示例:[DateTimeJsonConverter("yyyy-MM-dd HH:mm:ss.fff")]/// </summary>/// <param name="format">日期格式,示例:yyyy-MM-dd、yyyy-MM-dd HH:mm:ss、yyyy-MM-dd HH:mm:ss.fff等</param>[AttributeUsage(AttributeTargets.Property)]public class DateTimeJsonConverterAttribute(string format) : JsonConverterAttribute{private readonly string _format = format;/// <summary>/// 创建转换器/// </summary>public override JsonConverter CreateConverter(Type typeToConvert){if (typeToConvert != typeof(DateTime)){throw new ArgumentException($"This converter only works with DateTime, and it was provided {typeToConvert.Name}.");}return new DateTimeConverter(_format);}}
}
3. 在实体上使用自定义的DateTimeJsonConverter特性
/// <summary>/// 测试Dto/// </summary>public class TestDto{/// <summary>/// 唯一标识/// </summary>public string Id{ get; set; }/// <summary>/// 名称/// </summary>public string Name{ get; set; }/// <summary>/// 开始时间1/// </summary>[DateTimeJsonConverter("yyyy-MM-dd")]public DateTime StartTime1 { get; set; }/// <summary>/// 开始时间2/// </summary>[DateTimeJsonConverter("yyyy-MM-dd HH:mm:ss.fff")]public DateTime StartTime2 { get; set; }}