我正在尝试将Unix timestamp
反序列化为DateTime
。在我的情况下,我需要做更多的检查才能从时间戳设置属性到DateTime。如果我使用DateTime
中的Newtonsoft.Json
,则会将其反序列化为UTC
时间,我需要将其反序列化为特定时区
问题在于我无法获得正确的时间。好像我的long
解析字符串失败了。如果我可以获得long
unix时间戳,我可以使其余的逻辑工作
我有一个名为Alert
class Alert
{
// Some properties
[JsonConverter(typeof(UnixTimestampJsonConverter))]
public DateTime Created { get; set; }
// Some more properties
}
班级UnixTimestampJsonConverter
是
class UnixTimestampJsonConverter : JsonConverter
{
// Other override methods
public override object ReadJson (JsonReader reader, Type objectType,
object existingValue, JsonSerializer serializer)
{
if (reader.TokenType == JsonToken.EndObject)
return null;
if (reader.TokenType == JsonToken.StartObject) {
long instance = serializer.Deserialize<long> (reader);
return TimeUtils.GetCustomDateTime (instance);
}
return null;
}
}
TimeUtils.GetCustomDateTime (instance)
获取长unixtimestamp并将其转换为特定时区的DateTime对象。
我在Profile 78
的PCL库中,因此我对System.TimeZoneInfo
的访问权限有限,我使用PCL版NodaTime
进行其他时区计算。
如果有人感兴趣,这是Github上的项目 - MBTA Sharp
答案 0 :(得分:6)
我很确定您需要做的就是致电serializer.Deserialize
。这样做会使读者正确前进,您不需要做任何其他事情:
public class UnixTimestampJsonConverter : JsonConverter
{
public override object ReadJson(
JsonReader reader,
Type objectType,
object existingValue,
JsonSerializer serializer)
{
long ts = serializer.Deserialize<long>(reader);
return TimeUtils.GetMbtaDateTime(ts);
}
public override bool CanConvert(Type type)
{
return typeof(DateTime).IsAssignableFrom(type);
}
public override void WriteJson(
JsonWriter writer,
object value,
JsonSerializer serializer)
{
throw new NotImplementedException();
}
public override bool CanRead
{
get { return true; }
}
}