gpt4 book ai didi

c# - ServiceStack - 有没有办法强制所有序列化日期使用特定的 DateTimeKind?

转载 作者:可可西里 更新时间:2023-11-01 03:06:13 25 4
gpt4 key购买 nike

我有一个像这样的 POCO:

public class BlogEntry
{
public string Title { get; set; }
public DateTime Date { get; set; }
}

大多数时候它是从 Entity Framework 中提取的,但它可以并且将会在 Entity Framework 之外使用。

来自 EF 的 Date 的 DateTimeKind 是未指定的,根据我的阅读,这是正常的。

当我将此 POCO 缓存在 Redis 中(使用 ServiceStack Redis 客户端)时,它会返回本地的 DateTimeKind。

因此返回的对象存在抖动。第一遍(未缓存)具有没有偏移量的 ISO-8601 (DateTimeKind.Unspecified)。第二遍(缓存)是带有偏移量的 ISO-8601(来自具有 DateTimeKind.Local 的 Redis)。

有什么方法可以强制 ServiceStack JSON 序列化程序始终将日期解释为给定的 DateTimeKind? (我知道有一个“JsConfig.AppendUtcOffset”属性,但无论它是真还是假,这些值对我来说永远不会改变?)

或者在我键入的 RedisClient 的反序列化过程中的某个地方使 DateTimeKind 本地化?

我可以手动更改我的 POCO 以强制执行 DateTimeKind - 这很有效 - 但我希望出现一些不太容易出错的东西。

最佳答案

如果您需要比@mythz 的答案更可配置的东西,您可以通过覆盖 DateTime 和可选的 DateTime?序列化和/或反序列化方法。

强制将所有序列化的日期时间解释为 UTC

JsConfig<DateTime>.SerializeFn = time => new DateTime(time.Ticks, DateTimeKind.Local).ToString();

然后,如果 DateTime 不是指定格式,您可以更进一步并在反序列化时出错。当我想强制客户端在所有请求中指定时区时,我开始使用它,但不一定要求它始终是 Utc。

JsConfig<DateTime>.DeSerializeFn = time =>
{
if (!IsInCorrectDateFormat(time))
throw new System.Runtime.Serialization.SerializationException(BadDateTime);

return ServiceStack.Text.Common.DateTimeSerializer.ParseDateTime(time);
};

关于c# - ServiceStack - 有没有办法强制所有序列化日期使用特定的 DateTimeKind?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19694475/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com