记录Newtonsoft.Json的日常用法

最近在做一个使用基于.net mvc 实现前后台传输Json的实例。网上找了一些资料。发现在开发的时候,许多的数据交互都是以Json格式传输的。其中涉及序列化对象的使用的有DataContractJsonSerializer,JavaScriptSerializer和Json.net即Newtonsoft.Json.其中Json.net并不是微软的类库。是一个开源的世界级的Json操作类库。相对熟悉的只有JavaScriptSerializer这个序列化对象。但是,看了资料发现使用Json.net序列化对象比使用JavaScriptSerializer序列化对象性能上简直是一个天上一个地下。

以下是网上找到的它们之间的性能的对比图:

 

如何安装Json.net

因为Json.net不是微软的类库。所以,有两种方式使用:

方法1:可去官网下载压缩版。传送地址:https://www.newtonsoft.com。

方法2:可在vs中开发工具中 选择菜单中工具->Nuget程序包管理器->程序包管理器程序台->输入 Install-Package Newtonsoft.Json -Version 11.0.2 安装即可。

或者可以在选择菜单中工具->Nuget程序包管理器->管理解决方案的NuGet程序包->联机->查询到Json.net点击安装。

注意:如果安装出现错误信息为:“Newtonsoft.Json”已拥有为“Microsoft.CSharp”定义的依赖项。说明NuGet的版本太低。

第一步:请卸载低版本的NuGet。卸载步骤:打开VS->打开菜单“工具”-“扩展管理器”->选择“NuGet Package Manager”->点击“卸载”。

第二步:重启VS。

第三步:在“联机”选项中搜索“NuGet”,找到 NuGet Package Manager 点击下载,完成自动安装。

 如何使用Json.net

在需要使用的控制器中引用命名空间using.Newtonsoft.Json;

json.net基础用法是直接序列化和反序列化DataTable,DataSet,Entity Framework和Entity。

序列化:

//序列化DataTable
DataTable dt = new DataTable();
dt.Columns.Add("Age", Type.GetType("System.Int32"));
dt.Columns.Add("Name", Type.GetType("System.String"));
dt.Columns.Add("Sex", Type.GetType("System.String"));
dt.Columns.Add("IsMarry", Type.GetType("System.Boolean"));
for (int i = 0; i < 4; i++)
{
    DataRow dr = dt.NewRow();
    dr["Age"] = i + 1;
    dr["Name"] = "Name" + i;
    dr["Sex"] = i % 2 == 0 ? "" : "";
    dr["IsMarry"] = i % 2 > 0 ? true : false;
    dt.Rows.Add(dr);
}
Console.WriteLine(JsonConvert.SerializeObject(dt));            

反序列化:

 string json = JsonConvert.SerializeObject(dt);
 dt=JsonConvert.DeserializeObject<DataTable>(json);
 foreach (DataRow dr in dt.Rows)
 {
   Console.WriteLine("{0}\t{1}\t{2}\t{3}\t", dr[0], dr[1], dr[2], dr[3]);
 }

Json.net的高级用法

 1.忽略某些属性(OpIn的用法)

    [JsonObject(MemberSerialization.OptIn)]
    //OptIn默认情况下,所有的成员不会被序列化,类中的成员只有标有特性JsonProperty的才会被序列化。
    public partial class SysUser
    {
        public int ID { get; set; }
        public string UserName { get; set; }
        public string Email { get; set; }
        [JsonProperty]
        public string PassWord { get; set; }
        public DateTime dAddTime { get; set; }
        public virtual ICollection<SysUserRole> SysUserRole { get; set; }
    }

只用密码显示,其他不显示。

效果如图:

忽略某些属性(OpOut的用法)

 [JsonObject(MemberSerialization.OptOut)]
    //OptIn默认情况下,所有的成员不会被序列化,类中的成员只有标有特性JsonProperty的才会被序列化。
    public partial class SysUser
    {
        public int ID { get; set; }
        public string UserName { get; set; }
        public string Email { get; set; }
        [JsonIgnore]
        public string PassWord { get; set; }
        public DateTime dAddTime { get; set; }
        public virtual ICollection<SysUserRole> SysUserRole { get; set; }
    }

最后密码就被隐藏,其他都显示。

效果如图:

 2.日期处理

 使用Json.net处理的日期系统会自带iso日期标准,但是在实际的开发中大多数使用的可能是yyyy-MM-dd 或者yyyy-MM-dd HH:mm:ss两种格式的日期。所以,有两种解决方案:

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

    public class SysUser
    {
        public int ID { get; set; }
        public string UserName { get; set; }
        public string Email { get; set; }
        public string PassWord { get; set; }
        [JsonConverter(typeof(IsoDateTimeConverter))]
        public DateTime dAddTime { get; set; }
    }

方案2:如若IsoDateTimeConverter日期格式不是我们想要的可以继承该类实现自己的日期

 public class ChinaDateTimeConverter : DateTimeConverterBase
    {
        private static IsoDateTimeConverter dtConverter = new IsoDateTimeConverter { DateTimeFormat = "yyyy-MM-dd" };

        public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
        {
            return dtConverter.ReadJson(reader, objectType, existingValue, serializer);
        }

        public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
        {
            dtConverter.WriteJson(writer, value, serializer);
        }
    }

然后在Model中使用

public class SysUser
    {
        public int ID { get; set; }
        public string UserName { get; set; }
        public string Email { get; set; }
        public string PassWord { get; set; }
        [JsonConverter(typeof(ChinaDateTimeConverter))]
        public DateTime dAddTime { get; set; }
    }

效果如图:

文章摘自:https://www.cnblogs.com/mq0036/p/7017999.html

posted @ 2018-09-03 16:35 爱吃冬瓜不吃西瓜 阅读(...) 评论(...) 编辑 收藏