C# 返回Json数据格式忽略实体类空值属性

1、前言

在写项目的过程中,遇到了接口返回Json数据忽略实体类空值属性的问题,有的时候我们在往前台返回数据的时候实体类中的有些属性是用不到的,我们在写sql语句的时候就不会查询这些字段的值,那么对应实体类中这些没有值的属性就会使用默认值null,null不是我们所需要的,就需要过滤掉空值。 如下图:
在这里插入图片描述

2、解决办法

① 使用Newtonsoft.Json来进行空值处理

public string GetStudents()
{
    // 方法一:返回出去的是字符串类型
    JsonSerializerSettings setting = new JsonSerializerSettings { NullValueHandling = NullValueHandling.Ignore };
    string studentInfo = JsonConvert.SerializeObject(StudentBLL.GetStudents(), Formatting.Indented, setting);

    return studentInfo;
}

② 重写Json()方法

// 方法二:重写JsonResult类中的Json方法,在方法中进行空值处理
protected override JsonResult Json(object data, string contentType, Encoding encoding, JsonRequestBehavior behavior)
{
    return new JsonNetResult(data);
}

JsonNetResult工具类

using System.Web.Mvc;
using Newtonsoft.Json;

namespace Test.Utility
{
    public class JsonNetResult : JsonResult
    {
        public JsonNetResult(object data)
        {
            Data = data;
        }

        public override void ExecuteResult(ControllerContext context)
        {
            var response = context.HttpContext.Response;
            response.ContentType = "application/json";
            var serializedObject = JsonConvert.SerializeObject(Data, Formatting.None);
            response.Write(serializedObject);
        }
    }
}

说明:
var serializedObject = JsonConvert.SerializeObject(Data, Formatting.None);
如果Formatting.None说明在序列化数据的时没有设置忽略空值,这时候我们需要手动在实体类属性上面加上忽略空值的设置,如下代码:

using PetaPoco;
using Newtonsoft.Json;

namespace Test.Model
{
    [TableName("students")]
    public class Student
    {
        [Column("s_id")]
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
        public int? Id { get; set; }

        [Column("name")]
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
        public string Name { get; set; }

        [Column("age")]
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
        public int? Age { get; set; }

        [Column("telephone")]
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
        public string Telephone { get; set; }

        [Column("gender")]
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
        public string Gender { get; set; }

        [Column("email")]
        [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
        public string Email { get; set; }
    }
}
3、处理空值之后运行结果图

① 第一种方法
在这里插入图片描述

② 第二种方法
在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值