C#Json和Bson序列化中遇到的一些问题

【学习笔记】C#Json和Bson序列化中遇到的一些问题

2017年12月28日 10:39:19 oofpg 阅读数 2510

 版权声明:标明原创的版权均归本人所有,任何人或团体、机构全部转载或者部分转载、摘录,请保留本博客链接或标注来源。 https://blog.csdn.net/dai815904261/article/details/78919414

    在使用Mongodb进行开发的过程中,遇到一些Bson序列化的问题,以及如何将Mongo的Bson格式转化为标准的Json格式。所以在此处记下一些遇到的问题及我认为并不完善的解决方法以供参考和回顾。

一、在Bson的ToJson方法中int类型表示为“Number(x)”,可以使用如下方法改变Bson对象序列化时的输出格式:

var jsonWriterSettings = new JsonWriterSettings { OutputMode = JsonOutputMode.Strict };

string bsonStr = bsonObj.ToJson(jsonWriterSettings);

得到的bsonStr就是标准Json格式的字符串。

二、如果字段的类型为Mongodb.Bson.ObjectId(在Mongodb数据库中_id为此类型),在使用实例化JsonWriterSetting设置输出的序列化格式后得到的Json字段形如:"_id":{"$oid":"xxxxxxxxxxxxxxxxxxxxxxxx"}。这个字段一般不需要在Json中体现出来。可以使用如下方法使某一字段在序列化时被忽略:

在字段上打上标签(Attribute):[BsonIgnore]


 
  1. [BsonIgnore]

  2. public ObjectId _id { get; set; }

但是仅仅这样的话,在反序列化时会因为缺少_id字段而无法成功反序列化对象。可在包含_id字段的类上打上标签[BsonIgnoreExtraElements]:


 
  1. [BsonIgnoreExtraElements]

  2. public class Enterprise

  3. {

  4. [BsonIgnore]

  5. public ObjectId _id { get; set; }

  6. }

三、json序列化时,如果时间类型中的毫秒是0,则在序列化时会被省略,采用JsonSerialzerSettings可以进行设置。


 
  1. //设置不忽略时间的毫秒。

  2. JsonSerializerSettings settings = new JsonSerializerSettings();

  3. IsoDateTimeConverter dateConverter = new IsoDateTimeConverter

  4. {

  5. DateTimeFormat = "yyyy'-'MM'-'dd'T'HH':'mm':'ss.fff'Z'"

  6. };

  7. settings.Converters.Add(dateConverter);

  8.  
  9. string jsonStr = JsonConvert.SerializeObject(arr, settings);


 
  1. //反序列化设置 忽略不可匹配的项

  2.                     var jSetting = new JsonSerializerSettings();

  3. jSetting.NullValueHandling = NullValueHandling.Ignore;

  4.  
  5. string devicejsonstr = FileHelper.GetContentFromFile(devicePath);

  6. device = JsonConvert.DeserializeObject<List<Device>>(devicejsonstr, jSetting);

四、在使用Newtonsoft.Json进行序列化和反序列化时,可设置忽略项:


 
  1. //反序列化设置 忽略不可匹配的项

  2. var jSetting = new JsonSerializerSettings();

  3. jSetting.NullValueHandling = NullValueHandling.Ignore;

  4. device = JsonConvert.DeserializeObject<List<Device>>(jsonstr, jSetting);

原文地址:https://www.cnblogs.com/grj001/p/12225070.html