【C#笔记】Newtonsoft.Json 中 `[JsonIgnore]` 的作用详解

【C#笔记】Newtonsoft.Json 中 [JsonIgnore] 的作用详解

在使用 Newtonsoft.Json(Json.NET 进行对象序列化和反序列化时,我们经常会遇到这样一种需求:

有些属性我们希望 只在程序内部使用 ,而 不想被输出到 JSON 文件中

此时,一个简单的特性(Attribute)就能帮我们轻松搞定------那就是 [JsonIgnore]


一、[JsonIgnore] 是什么?

[JsonIgnore] 是 Newtonsoft.Json 提供的一个特性,用于在 JSON 序列化和反序列化过程中忽略指定属性或字段

简而言之:

  • 序列化 时,它不会被写入到 JSON 字符串中;
  • 反序列化 时,即使 JSON 里包含该字段,也不会赋值给对象。

二、基本示例

来看一个简单的例子 👇

csharp 复制代码
using Newtonsoft.Json;

public class Person
{
    public string Name { get; set; }

    [JsonIgnore]
    public int Age { get; set; }

    public string City { get; set; }
}

var person = new Person
{
    Name = "Alice",
    Age = 30,
    City = "Shanghai"
};

string json = JsonConvert.SerializeObject(person, Formatting.Indented);
Console.WriteLine(json);

输出结果如下:

json 复制代码
{
  "Name": "Alice",
  "City": "Shanghai"
}

你会发现,Age 字段并没有出现在结果中,因为它被 [JsonIgnore] 忽略了。


三、反序列化时的行为

[JsonIgnore] 不仅会影响序列化,也会影响反序列化。

csharp 复制代码
string json = @"{ ""Name"": ""Alice"", ""Age"": 30, ""City"": ""Shanghai"" }";

var person = JsonConvert.DeserializeObject<Person>(json);
Console.WriteLine(person.Age); // 输出:0

即使 JSON 中有 "Age": 30

反序列化后的 person.Age 仍然是默认值 0

因为 [JsonIgnore] 告诉 Json.NET 不要理会这个字段。


四、典型使用场景

[JsonIgnore] 的用途非常广泛,以下是一些常见场景:

  1. 隐藏敏感信息

    csharp 复制代码
    [JsonIgnore]
    public string Password { get; set; }

    防止密码、Token 等被写入 JSON 文件或日志。

  2. 避免循环引用

    csharp 复制代码
    public class Node
    {
        public string Name { get; set; }
        [JsonIgnore]
        public Node Parent { get; set; }
    }

    否则可能出现无限递归,导致序列化失败。

  3. 排除运行时属性

    某些属性只在内存中使用,不需要被保存或传输。


五、与其他 Json 特性的区别

特性 作用
[JsonIgnore] 忽略序列化与反序列化
[JsonProperty("CustomName")] 改变 JSON 字段名
[JsonRequired] 要求反序列化时必须存在该字段,否则报错
[JsonConverter(typeof(...))] 使用自定义转换器处理字段
[JsonExtensionData] 存放未知或额外的 JSON 字段

可以看到,[JsonIgnore] 是最简单直接的控制手段。


六、进阶:仅在特定情况下忽略

有时我们希望更灵活地控制,比如只忽略"空值"或"序列化时才忽略"。

Newtonsoft.Json 还提供了更细粒度的设置方式:

csharp 复制代码
JsonConvert.SerializeObject(obj, new JsonSerializerSettings
{
    NullValueHandling = NullValueHandling.Ignore
});

或者:

csharp 复制代码
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
public string Address { get; set; }

不过,如果你只是想彻底排除一个字段,[JsonIgnore] 是最直接、最推荐的方式。


七、总结

关键点 说明
特性名称 [JsonIgnore]
所属库 Newtonsoft.Json
作用 忽略属性的序列化和反序列化
典型场景 隐藏敏感字段、避免循环引用、跳过临时变量
替代方案 JsonSerializerSettingsJsonProperty

一句话总结:

当你不想让某个属性出现在 JSON 中时,加上 [JsonIgnore],它就会"消失得无影无踪"。


相关推荐
Scout-leaf3 天前
WPF新手村教程(三)—— 路由事件
c#·wpf
用户298698530143 天前
程序员效率工具:Spire.Doc如何助你一键搞定Word表格排版
后端·c#·.net
mudtools4 天前
搭建一套.net下能落地的飞书考勤系统
后端·c#·.net
玩泥巴的4 天前
搭建一套.net下能落地的飞书考勤系统
c#·.net·二次开发·飞书
唐宋元明清21884 天前
.NET 本地Db数据库-技术方案选型
windows·c#
lindexi4 天前
dotnet DirectX 通过可等待交换链降低输入渲染延迟
c#·directx·d2d·direct2d·vortice
西岸行者4 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习
starlaky4 天前
Django入门笔记
笔记·django
勇气要爆发4 天前
吴恩达《LangChain LLM 应用开发精读笔记》1-Introduction_介绍
笔记·langchain·吴恩达
悠哉悠哉愿意4 天前
【单片机学习笔记】串口、超声波、NE555的同时使用
笔记·单片机·学习