记录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 = ; i < ; i++)
{
DataRow dr = dt.NewRow();
dr["Age"] = i + ;
dr["Name"] = "Name" + i;
dr["Sex"] = i % == ? "男" : "女";
dr["IsMarry"] = i % > ? 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[], dr[], dr[], dr[]);
}
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
记录Newtonsoft.Json的日常用法的更多相关文章
- Newtonsoft.Json 的高级用法
Ø 简介 接着前一篇http://www.cnblogs.com/abeam/p/8295765.html,继续研究 Newtonsoft.Json 的一些高级用法.主要包括: 1. JSON ...
- Newtonsoft.Json 的解析用法。
JsonView是查看和分析json的利器,目录下的Newtonsoft.Json.dll ,我们可以当第三方引用之. >>> //想服务器端发送请求,获取订单信息 myReques ...
- 记一次 Newtonsoft.Json 巧妙的用法(C#)
数据添加的功能 有一个表格提交数据如下: 是否选择和文本值.分开保存到数据库太麻烦.取得时候也麻烦 想到了存成json数据.一个字段就可以了. html代码: <table class=&quo ...
- Newtonsoft.Json 的基本用法
Ø 前言 说起 C# 对 JSON 的操作(序列化与反序列化),大家都会想到 JavaScriptSerializer.DataContractJsonSerializer 与 Newtonsoft ...
- Newtonsoft.Json高级用法(转)
手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口多次修改中,实体添加了很多字段用于中间计算或者存储,然后最终用Newtonsoft.Json进行序列化返回数 ...
- 【转】 Newtonsoft.Json高级用法
手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口多次修改中,实体添加了很多字段用于中间计算或者存储,然后最终用Newtonsoft.Json进行序列化返回数 ...
- Newtonsoft.Json高级用法 1.忽略某些属性 2.默认值的处理 3.空值的处理 4.支持非公共成员 5.日期处理 6.自定义序列化的字段名称
手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口多次修改中,实体添加了很多字段用于中间计算或者存储,然后最终用Newtonsoft.Json进行序列化返回数 ...
- 转:Newtonsoft.Json高级用法
原文地址:http://www.cnblogs.com/yanweidie/p/4605212.html 手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口多 ...
- Newtonsoft.Json高级用法,json序列号,model反序列化,支持序列化和反序列化DataTable,DataSet,Entity Framework和Entity,字符串
原文地址:https://www.cnblogs.com/yanweidie/p/4605212.html 手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口 ...
随机推荐
- 自我理解node.js相比java的优势
今天学习node.js,相比于之前学习过的java,node.js有一些优越之处.原因是它是一个基于Chrome v8引擎建立的JavaScript运行平台. (1)创建服务器:自行服务器来监听客户端 ...
- uva10256(计算几何)
省选前练模板系列: #include<cmath> #include<cstdio> #include<cstring> #include<iostream& ...
- 微信接收QQ邮箱e-mail
- Leetcode 34 Find First and Last Position of Element in Sorted Array 解题思路 (python)
本人编程小白,如果有写的不对.或者能更完善的地方请个位批评指正! 这个是leetcode的第34题,这道题的tag是数组,需要用到二分搜索法来解答 34. Find First and Last Po ...
- 推导正交投影(Orthographic Projection)
定义六个面 left right bottom top near far 然后三个轴分开考虑 x轴 视椎体的x范围在[l,r],我们要变换到[-1,1] 1 减去l变换到[0, r-l] 2 乘以 ...
- python爬虫学习之爬取全国各省市县级城市邮政编码
实例需求:运用python语言在http://www.ip138.com/post/网站爬取全国各个省市县级城市的邮政编码,并且保存在excel文件中 实例环境:python3.7 requests库 ...
- IM系统的MQ消息中间件选型:Kafka还是RabbitMQ?
1.前言 在IM这种讲究高并发.高消息吞吐的互联网场景下,MQ消息中间件是个很重要的基础设施,它在IM系统的服务端架构中担当消息中转.消息削峰.消息交换异步化等等角色,当然MQ消息中间件的作用远不止于 ...
- 第64节:Java中的Spring Boot 2.0简介笔记
Java中的Spring Boot 2.0简介笔记 spring boot简介 依赖java8的运行环境 多模块项目 打包和运行 spring boot是由spring framework构建的,sp ...
- centos6安装cas5
cas是Central Authentication Service的缩写,中文为中央认证服务,在这里我就不说理论了,在公司里项目研发需要cas平台,所以经过两天研究,搞了一个简化版的cas服务,有不 ...
- Source Qualifter组件中sqlquery过长导致截取
问题:Source Qualifter组件中sqlquery过长导致截取原因:Source Qualifter组件中sqlquery可以接受的最长字符数是32767个字符,超过这个数字会导致截取解决方 ...