json】1.Newtonsoft—Json.NET常用方法简述(newtonsoft.json下载)

网友投稿 1209 2022-09-11

【Json】1.Newtonsoft—Json.NET常用方法简述(newtonsoft.json-)

【Json】1.Newtonsoft—Json.NET常用方法简述(newtonsoft.json-)

Json.NET常用方法汇总(可解决日常百分之90的需求)

0.Json.NET基础用法

首先去官网-最新的Newtonsoft.Json.dll(也可以使用VS自带的NuGet搜索Json.NET-(-下图第二个))并引用至项目。

(1)序列化实体类(将实体类对象序列化为Json字符串)

结果:

(2)反序列化(将Json字符串反序列化为实体类对象)

1.序列化与反序列化时忽略某些属性

(1)忽略类内所有属性

[JsonObject(MemberSerialization.OptIn)]用于在序列化与反序列化时忽略一个类里所有的属性,只有当在类内属性上打特性标签[JsonProperty]时才支持序列化与反序列化。所以[JsonObject(MemberSerialization.OptIn)]常用于与[JsonProperty]配合使用。

例:

(2)序列化所有属性(默认)

默认实体类上默认打着[JsonObject(MemberSerialization.OptOut)]特性标签(可以省略不写),如果要忽略某些属性,要在属性上打[JsonIgnore]。

例:

(3)动态控制实体类属性的是否忽略序列化(默认)

当某些条件下需要序列化A属性和B属性,某些情况下需要忽略A属性与B属性,我们该怎么做?

  答:使用JsonSerializerSettings设置某实体类对象要忽略序列化的属性(配合if与else控制属性的动态忽略)。

例:以下方式忽略p对象的Age属性与IsMarry属性:

JsonSerializerSettings jsetting=new JsonSerializerSettings();

  jsetting.ContractResolver = new LimitPropsContractResolver(new string[] { "Age", "IsMarry" });

  Console.WriteLine(JsonConvert.SerializeObject(p, Formatting.Indented, jsetting));

2.默认值处理

(1)设置属性默认值

在属性上打 [DefaultValue("xxx")]

3.空值处理

(1)不序列化为null的属性(使用JsonSerializerSettings方式)

ps:使用这种方式可能bool为false的也无法序列,最后的结果只包含Birthday、Sex、Name、Age。

(2)不序列化为null的属性(使用特性标签方式)

[JsonProperty(NullValueHandling=NullValueHandling.Ignore)]

public Room room { get; set; }

4.序列化私有成员

因为默认只序列化public的成员,所以如果想序列化private成员,要在实体类的属性上打[JsonProperty]标签。

[JsonProperty]

private int Height { get; set; }

5.自定义序列化名称

在序列化与反序列化时可以自定义序列化出字符串的属性名称,如下代码可以将实体类的Name属性序列化为CName属性,并且可以将Json中的CName反序列化为当前实体类的Name属性。(双向)

[JsonProperty(PropertyName = "CName")]

public string Name { get; set; }

6.日期处理

(1)解决方案1:在可以动Model代码的情况下

系统自带的DateTime会格式化成iso日期标准,但是实际使用过程中大多数使用的可能是yyyy-MM-dd 或者yyyy-MM-dd HH:mm:ss两种格式的日期,解决办法是可以将DateTime类型改成string类型自己格式化好,然后在序列化。

  例:

ps:代码思路是不去序列化StartTime属性,而去序列化string类型的m_StartTime属性(m_StartTime相当于StartTime属性的私有字段)。

(2)解决方案2:使用DateTimeConverterBase

Json.Net提供了IsoDateTimeConverter日期转换这个类,可以通过JsnConverter实现相应的日期转换

[JsonConverter(typeof(IsoDateTimeConverter))]

public DateTime Birthday { get; set; }

但是IsoDateTimeConverter日期格式(yyyy-MM-ddTHH:mm:ss)不是我们想要的,我们可以继承该类实现自己的日期

  例:

使用方式:

[JsonConverter(typeof(ChinaDateTimeConverter))]

public DateTime Birthday { get; set; }

7.以驼峰命名法序列化

有时我们会碰到这种需求,比如我们代码里实体类型的属性名称均是以大写字母开头,如Name、StartTime等,但是要求我们序列出的Json字符串的属性名称要以小写字母开头,如name、startTime、endTime等。我们可以使用如下代码解决

JsonSerializerSettings setting = new JsonSerializerSettings();

setting.ContracResolver = new CamelCasePropertyNamesContractResolver();

string jsonStr = JsonConvert.Serializeobject(p, Newtonsoft.json.Formatting.Indented, setting);

这样子的话,在序列实体类对象p的属性时,属性名称将由PersonName转换为personName。

8.枚举的序列化

枚举默认序列化为枚举的Int值,如果想要序列化为枚举string值,使用如下方式

[JsonConverter(typeof(StringEnumConverter))]

  public NotifyTypeEnum Type { get; set; }

9.将多个数据类型序列化为1个Json对象(序列化匿名类)

有时我们有这样的需求,对方要求我们传输过去的Json字符串要包含我们多个实体类型的信息,笨方法就是重新构建一个符合要求的实体类型,但是我们又更好的方法,我们可以使用匿名类,把Json需要的信息均放在匿名类中,我们可以对匿名类进行序列化。

例:

我们只需要对上面的匿名对象“json”序列化即可。

10.使用JsonConverter自定义属性序列化规则(json格式转换器)

(1)将属性值由double类型序列化时转为字符串类型

使用方式:

[JsonConverter(typeof(DoubleToStringConverter))]

public double Count{get;set;}

ps:这样子,就可以把原本序列化出的Json字符串   Count : 12.3   转化为   Count : "12.3"

  ps:[JsonConverter(typeof(DoubleToStringConverter))]也可以打在类上,表示全局设置

(2)枚举转换为int字符串

为什么要进行这样的转换呢?

因为枚举类型在序列化时默认序列化为枚举的int类型,即如下代码:

结果为:

有时候会有这样的需求,序列化出的属性值均要为字符串格式,即要将上图结果的3改为"3"。这时候就需要自定义转换了!

代码如下:

共2页: 上一页12下一页

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:EasyCVR程序启动后,流量统计在配置中修改未能生效的问题修复
下一篇:如何对Active Directory的用户进行高效的登录审核?
相关文章

 发表评论

暂时没有评论,来抢沙发吧~