我有以下实体类:
public class FacebookComment : BaseEntity { [BsonId(IdGenerator = typeof(ObjectIdGenerator))] [BsonRepresentation(MongoDB.Bson.BsonType.ObjectId)] [JsonProperty("_id")] public ObjectId Id { get; set; } public int? OriginalId { get; set; } public DateTime Date { get; set; } public string Message { get; set; } public string Sentiment { get; set; } public string Author { get; set; } }
当该对象被序列化为JSON时,我希望将Id字段写为“_id”:{…}. AFAIK,我只需要将所需的属性名称传递给JsonProperty属性;我应该很好去.但是,当我调用JsonConvert.SerializeObject;它似乎忽略了我的属性,并呈现出来:
{ Author: "Author name",Date: "/Date(1321419600000-0500)/",DateCreated: "/Date(1323294923176-0500)/",Id: { CreationTime: "/Date(0)/",Increment: 0,Machine: 0,Pid: 0,Timestamp: 0 },Message: "i like stuff",OriginalId: null,Sentiment: "Positive" }
有任何想法吗?在这个问题上工作了一个小时;不知道为什么串行器似乎忽略了我的JsonProperty.
任何建设性的输入都不胜感激.
解决方法
简短答案:确保所有程序集都引用相同的JSON.NET DLL.可能发生的情况是您正在一个程序集中从一个DLL中应用[JsonProperty],并从不同的程序集序列化对象,该程序集正在寻找不同的[JsonProperty],但CLR对象类型不同,因此它被有效地忽略.
更长的答案:我只是有这个问题,但幸运的是我有一个类与JsonProperty一起工作,一个没有这样我可以做一些侦探工作.
我将非工作阶层剥离到最低限度,并将其与工人阶级进行比较,看不出任何差异 – 除了非工作阶级在不同的组合中.
当我把课程转移到另一个组件时,它应该是完美的.
我捅了一下试图查看JSON序列化的命名空间,但这似乎并不适用,所以我看了这些引用,当然我已经在我的实体DLL和NUGET 4.5版本中引用了一个旧的JSONNET3.5 dll在我的主要项目文件.
这给了我两个[JsonProperty]属性的实例(这只是一个常规类),只是因为它们被命名为相同,并不意味着串行器甚至会识别属性.