【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],它就会"消失得无影无踪"。


相关推荐
Mike_6661 小时前
txt_json和xml_json
xml·python·json
周周不一样1 小时前
Andorid基础笔记2-jar&反射
笔记·pycharm·jar
DevOpenClub1 小时前
语义化获取站点 JSON 结构内容 API 接口
json
智者知已应修善业1 小时前
【51单片机单按键切换广告屏】2023-5-17
c++·经验分享·笔记·算法·51单片机
hhh3u3u3u1 小时前
Visual C++ 6.0中文版安装包下载教程及win11安装教程
java·c语言·开发语言·c++·python·c#·vc-1
加号32 小时前
【C#】实现沃德普线光控制器通信控制(附完整源码)
开发语言·c#
凉、介2 小时前
别再把 PCIe 的 inbound/outbound、iATU 和 eDMA 混为一谈
linux·笔记·学习·嵌入式·pcie
lzhdim3 小时前
SharpCompress:跨平台的 C# 压缩与解压库
开发语言·c#
~plus~5 小时前
.NET 8 C# 委托与事件实战教程
网络·c#·.net·.net 8·委托与事件·c#进阶
雷工笔记5 小时前
MES / WMS / AGV 交互时序图及生产管理模块界面设计清单
人工智能·笔记