C# Newtonsoft.Json object 转 json 为空

问题

使用 Newtonsoft.Json 框架 object 转 json,发现用 internal 修饰的属性,不能被转json

JsonConvert.SerializeObject(obj)

例如

internal sealed class CountSheet
{
    internal List<CountSheetItem> ArrayOfItems { get; set; }
    internal string AssignedUser { get; set; }
    internal string Comments { get; set; }
    internal string CountDate { get; set; }
    internal int DocEntry { get; set; }
    internal int DocNum { get; set; }
    internal int LineCount { get; set; }
    internal string Reference { get; set; }
    internal int Started { get; set; }
}

属性值被声明为 internal 类型的,转 json 后,发现是空{}。

分析

查了资料发现 Newtonsoft.Json 这个框架支持 public 类型的属性转 json, 其他类型的不会被转,如果需要其他类型的也转 json,需要添加 [JsonProperty] 修饰。

internal sealed class CountSheet
{
    [JsonProperty]
    internal List<CountSheetItem> ArrayOfItems { get; set; }
    [JsonProperty]
    internal string AssignedUser { get; set; }
    [JsonProperty]
    internal string Comments { get; set; }
    [JsonProperty]
    internal string CountDate { get; set; }
    [JsonProperty]
    internal int DocEntry { get; set; }
    [JsonProperty]
    internal int DocNum { get; set; }
    [JsonProperty]
    internal int LineCount { get; set; }
    [JsonProperty]
    internal string Reference { get; set; }
    [JsonProperty]
    internal int Started { get; set; }
}

添加 [JsonProperty] 前需要先 using Newtonsoft.Json;

解决

  1. 将属性修饰为 public 类型

  1. 添加 [JsonProperty]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
C#中,使用Newtonsoft.Json处理日期类型的方法是通过配置JsonSerializerSettings中的DateFormatString属性。可以使用以下代码示例来设置日期格式: ```csharp JsonSerializerSettings settings = new JsonSerializerSettings { DateFormatString = "yyyy-MM-dd HH:mm:ss" }; string json = JsonConvert.SerializeObject(yourObject, settings); ``` 在上面的代码中,我们创建了一个JsonSerializerSettings对象,并将DateFormatString属性设置为所需的日期格式(例如"yyyy-MM-dd HH:mm:ss")。然后,我们可以使用JsonConvert.SerializeObject方法将对象序列化为JSON字符串,同时传递配置的JsonSerializerSettings对象。 请注意,你需要使用Newtonsoft.Json库,该库可以从官方网站下载并添加到你的项目中。确保在项目中包含Newtonsoft.Json.dll文件,并在代码中引用该库。 引用中提到了在SQL Server的CLR中使用Newtonsoft.Json进行比较的示例,这与在C#中处理日期类型的问题无关,请忽略该引用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SQLSERVER CLR借助Newtonsoft.JSON实现JSON内容是否相同对比功能](https://download.csdn.net/download/sugerlcc/85402800)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Newtonsoft.Json-for-Unity.Converters:Newtonsoft.Json的常见Unity类型换器。 与jilleJrNewtonsoft....](https://download.csdn.net/download/weixin_42112894/18775229)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [C# Newtonsoft.Json类库源码包](https://download.csdn.net/download/weixin_38658471/18584713)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Morris_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值