.net core 对象序列化为Json及Json反序列化关于DataContractJsonSerializer和Newtonsoft使用的完整案例,源码已更新至开源模板
很多人告诉你怎么用,但是却不会告诉你用什么好。不知道在进行序列化和反序列化Json时用那个好,因为有太多选择,如.NET Framework下可以选DataContractJsonSerializer、JavaScriptSerializer、Newtonsoft.Json,但是JavaScriptSerializer在.net core下已经没有了,那么大家还有两种选择DataContractJsonSerializer和Newtonsoft.Json,因为这两个都有人用,所以我做了完整的对象转换demo进行了测试,这里我不仅和大家讲如何使用,并且还把我自己写的参与测试并告诉各位怎么测试的。
为了节约开发时间,我们把解决方案收入到一个个demo中,方便以后即拿即用。而且这些demo有博客文档支持,帮助任何人非常容易上手开发跨平台的.net core。随着时间的推移,我们的demo库会日益强大请及时收藏GitHub。
好了在讲序列化及反序列化之前先把我们的测试结果分享给大家,十万数据测速比较告诉你为何用Newtonsoft。
一、首先在Common公用项目中引用Newtonsoft的类库
Install-Package Newtonsoft.Json -Version -beta2
二、在Common公用项目中添加CommonHelper
#region model<->json(对象和json互转) #region DataContractJsonSerializer public static string SerializeDataContractJson<T>(T obj) { DataContractJsonSerializer json = new DataContractJsonSerializer(obj.GetType()); using (MemoryStream stream = new MemoryStream()) { json.WriteObject(stream, obj); string szJson = Encoding.UTF8.GetString(stream.ToArray()); return szJson; } } public static T DeserializeDataContractJson<T>(string szJson) { T obj = Activator.CreateInstance<T>(); using (MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(szJson))) { DataContractJsonSerializer serializer = new DataContractJsonSerializer(obj.GetType()); return (T)serializer.ReadObject(ms); } } #endregion #region Newtonsoft static public string SerializeJSON<T>(T data) { return Newtonsoft.Json.JsonConvert.SerializeObject(data); } static public T DeserializeJSON<T>(string json) { return Newtonsoft.Json.JsonConvert.DeserializeObject<T>(json); } #endregion #endregion #region datatable<->json(datatable和json互转) public static string SerializeDataTableToJSON(DataTable dt) { return Newtonsoft.Json.JsonConvert.SerializeObject(dt); } public static DataTable SerializeJSONToDataTable(string json) { return Newtonsoft.Json.JsonConvert.DeserializeObject<DataTable>(json); } #region 自己写datatable转json用于测试速度对比下 public static string MyDataTableToJson(DataTable dt) { StringBuilder JsonString = new StringBuilder(); ) { JsonString.Append("{ "); JsonString.Append("\"TableInfo\":[ "); ; i < dt.Rows.Count; i++) { JsonString.Append("{ "); ; j < dt.Columns.Count; j++) { ) { JsonString.Append("\"" + dt.Columns[j].ColumnName.ToString() + "\":" + "\"" + dt.Rows[i][j].ToString() + "\","); } ) { JsonString.Append("\"" + dt.Columns[j].ColumnName.ToString() + "\":" + "\"" + dt.Rows[i][j].ToString() + "\""); } } ) { JsonString.Append("} "); } else { JsonString.Append("}, "); } } JsonString.Append("]}"); return JsonString.ToString(); } else { return null; } } #endregion #endregion
三、控制器添加Json处理相应方法(我这里整合所有到了HomeController下的Json中了,你们不需要计时,用的时候只需要调用CommonHelper的相关方法即可)
public IActionResult Json() { List<Article> articleList = new List<Article>(); ; x < ; x++) { Article article = new Article(); article.Context = "内容:" + x; article.Id = x + ; article.CreateTime = DateTime.Now; article.Title = "标题:" + x; articleList.Add(article); } #region 单个对象与json互转 Article articletest = new Article(); articletest.Context = "内容"; articletest.Id = ; articletest.CreateTime = DateTime.Now; articletest.Title = "标题"; string json11 = CommonHelper.SerializeDataContractJson(articletest); string json12 = CommonHelper.SerializeJSON(articletest); Article article1 = CommonHelper.DeserializeDataContractJson<Article>(json11); Article article2 = CommonHelper.DeserializeJSON<Article>(json12); #endregion #region 记录10万对象集合与json互转用时比较 //SerializeDataContractJson 10万对象转json System.Diagnostics.Stopwatch watch1 = new System.Diagnostics.Stopwatch(); watch1.Start(); //开始监视代码运行时间 string json1 = CommonHelper.SerializeDataContractJson(articleList); TimeSpan timespan1 = watch1.Elapsed; //获取当前实例测量得出的总时间 watch1.Stop(); //停止监视 ViewBag.t1= timespan1.TotalSeconds; //Newtonsoft 10万对象转json System.Diagnostics.Stopwatch watch2 = new System.Diagnostics.Stopwatch(); watch2.Start(); string json2 = CommonHelper.SerializeJSON(articleList); TimeSpan timespan2 = watch2.Elapsed; watch2.Stop(); ViewBag.t2 = timespan2.TotalSeconds; //SerializeDataContractJson 10万json转对象 System.Diagnostics.Stopwatch watch3 = new System.Diagnostics.Stopwatch(); watch3.Start(); List<Article> list1 = CommonHelper.DeserializeDataContractJson<List<Article>>(json1); TimeSpan timespan3 = watch3.Elapsed; watch3.Stop(); ViewBag.t3 = timespan3.TotalSeconds; //Newtonsoft 10万json转对象 System.Diagnostics.Stopwatch watch4 = new System.Diagnostics.Stopwatch(); watch4.Start(); List<Article> list2 = CommonHelper.DeserializeJSON<List<Article>>(json2); TimeSpan timespan4 = watch4.Elapsed; watch4.Stop(); ViewBag.t4 = timespan4.TotalSeconds; #endregion #region 记录10万datatable与json互转用时比较 DataTable tblDatas = new DataTable("Datas"); DataColumn dc = null; dc = tblDatas.Columns.Add("ID", Type.GetType("System.Int32")); dc.AutoIncrement = true;//自动增加 dc.AutoIncrementSeed = ;//起始为1 dc.AutoIncrementStep = ;//步长为1 dc.AllowDBNull = false;// dc = tblDatas.Columns.Add("Product", Type.GetType("System.String")); dc = tblDatas.Columns.Add("Version", Type.GetType("System.String")); dc = tblDatas.Columns.Add("Description", Type.GetType("System.String")); ; x < ; x++) { DataRow newRow = tblDatas.NewRow(); newRow["Product"] = "西游记" + x; newRow["Version"] = "" + x; newRow["Description"] = x; tblDatas.Rows.Add(newRow); } //Newtonsoft 10万DataTable转json System.Diagnostics.Stopwatch watch5 = new System.Diagnostics.Stopwatch(); watch5.Start(); string json5 = CommonHelper.SerializeDataTableToJSON(tblDatas); TimeSpan timespan5 = watch5.Elapsed; watch5.Stop(); ViewBag.t5 = timespan5.TotalSeconds; //Newtonsoft 10万json转DataTable System.Diagnostics.Stopwatch watch6 = new System.Diagnostics.Stopwatch(); watch6.Start(); DataTable dataTable = CommonHelper.SerializeJSONToDataTable(json5); TimeSpan timespan6 = watch6.Elapsed; watch6.Stop(); ViewBag.t6 = timespan6.TotalSeconds; //自己写的 10万DataTable转json System.Diagnostics.Stopwatch watch7 = new System.Diagnostics.Stopwatch(); watch7.Start(); string json7 = CommonHelper.MyDataTableToJson(tblDatas); TimeSpan timespan7 = watch7.Elapsed; watch7.Stop(); ViewBag.t7 = timespan7.TotalSeconds; #endregion return View(); }
四、前端设计(这里也没啥设计了,只是做了展示,代码我还是贴出来吧)
<div style="width:80%;margin:auto;text-align:center;"> <div class="cover" style="border: 1px solid #D6D6D6;padding: 5px;"> <h2>10万对象与json互转</h2> <span>SerializeDataContractJson:对象集合转json(@ViewBag.t1 秒),json转对象集合(@ViewBag.t3 秒)</span><br /> <span>Newtonsoft:对象集合转json(@ViewBag.t2 秒),json转对象集合(@ViewBag.t4 秒)</span> </div> <div class="cover" style="border: 1px solid #D6D6D6;padding: 5px;"> <h2>10万datatable与json互转</h2> <span>Newtonsoft:datatable转json(@ViewBag.t5 秒),json转datatable(@ViewBag.t6 秒)</span><br /> <span>自己码:datatable转json(@ViewBag.t7 秒)</span> </div> </div>
五、那么看下效果吧。
开源地址 动动小手,点个推荐吧!
注意:我们机遇屋该项目将长期为大家提供asp.net core各种好用demo,旨在帮助.net开发者提升竞争力和开发速度,建议尽早收藏该模板集合项目。
.net core 对象序列化为Json及Json反序列化关于DataContractJsonSerializer和Newtonsoft使用的完整案例,源码已更新至开源模板的更多相关文章
- 建议收藏备用:.net core使用QRCoder生成普通二维码和带Logo的二维码详细使用教程,源码已更新至开源模板
随着互联网越来越生活化,二维码的使用越来越普遍,不论是扫码支付还是扫码关注引流,似乎我们总是离不开二维码,那么很多需要推广的文章或社区想要自己的二维码,那么你是不是需要在网站直接提供给用户呢?很多开发 ...
- 建议收藏:.net core 使用导入导出Excel详细案例,精心整理源码已更新至开源模板
还记得刚曾经因为导入导出不会做而发愁的自己吗?我见过自己前同事因为一个导出改了好几天,然后我们发现虽然有开源的库但是用起来却不得心应手,主要是因为百度使用方案的时候很多方案并不能解决问题. 尤其是尝试 ...
- 类对象序列化为json串,json串反序列化为类对象
1.类对象序列化为json串: 方法一: class P(object): def __init__(self,name,age,sex): self.name=name self.age=age s ...
- JS对象序列化为JSON对象的方法
var $ = $ || {}; /** * 将JS对象序列化为JSON字符串 * @param {Mixed} o The variable to decode * @return {String} ...
- 匿名对象序列化为XML
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.X ...
- JavaScriptSerializer类 对象序列化为JSON,JSON反序列化为对象
JavaScriptSerializer 类由异步通信层内部使用,用于序列化和反序列化在浏览器和 Web 服务器之间传递的数据.说白了就是能够直接将一个C#对象传送到前台页面成为javascript对 ...
- JavaScriptSerializer类 对象序列化为JSON,JSON反序列化为对象 。
JavaScriptSerializer 类由异步通信层内部使用,用于序列化和反序列化在浏览器和 Web 服务器之间传递的数据.说白了就是能够直接将一个C#对象传送到前台页面成为javascript对 ...
- .NET Core 对象到字节数组的序列化和反序列化
.NET Core中利用MemoryStream和BinaryFormatter可以实现对象到字节数组的序列化和反序列化: 定义ObjectSerializer类,实现对象到字节数组的序列化和反序列化 ...
- Python: 自定义类对象序列化为Json串
之前已经实现了Python: Json串反序列化为自定义类对象,这次来实现了Json的序列化. 测试代码和结果如下: import Json.JsonTool class Score: math = ...
随机推荐
- .Net Core AA.FrameWork应用框架介绍
开发多年,一直在从社区获取开源的便利,也深感社区力量的重要性,今天开源一个应用基础框架AA.FrameWork,也算是回馈社区,做出一点点贡献,希望能够帮助类似当年入行的我. AA.FrameWork ...
- 解决window.onload延迟加载问题
window.onload方法,表示当页面所有的元素都加载完毕,并且所有要请求的资源也加载完毕才触发执行function这个匿名函数里边的具体内容.这样肯定保证了代码在domReady之后执行.使用w ...
- spring Bean的三种配置方式
Spring Bean有三种配置方式: 传统的XML配置方式 基于注解的配置 基于类的Java Config 添加spring的maven repository <dependency> ...
- SpringCloud-动态配置变化监控-获取变化(支持Config、Nacos)
SpringCloud-动态配置变化监控-获取变化(支持Config.Nacos) qq交流群: 812321371 微信交流群: MercyYao 简介 配置中心有原生的 SpringCloud C ...
- springboot 自定义LocaleResolver切换语言
springboot 自定义LocaleResolver切换语言 我们在做项目的时候,往往有很多项目需要根据用户的需要来切换不同的语言,使用国际化就可以轻松解决. 我们可以自定义springboor中 ...
- Jenkins邮件收发(qq邮箱)
首先确认QQ邮箱SMTP服务器的地址和端口号.如下图所示,请谨记,JENKINS全局邮箱配置需要使用: 步骤1:开启QQ邮箱的smtp服务:登陆QQ邮箱-设置-账户-开启POP3/SMTP服务-完成“ ...
- Webshell免杀绕过waf
转自圈子404师傅 0x01 前言# 尽最大努力在一文中让大家掌握一些有用的WEBSHELL免杀技巧 0x02 目录# 关于eval 于 assert 字符串变形 定义函数绕过 回调函数 回调函数变形 ...
- 域渗透-Kerberos协议中spn的应用
0x01 关于SPN 服务主体名称(SPN)是Kerberos客户端用于唯一标识给特定Kerberos目标计算机的服务实例名称. 服务主体名称是服务实例(可以理解为一个服务,比如 HTTP.MSSQL ...
- (20)ASP.NET Core EF创建模型(必需属性和可选属性、最大长度、并发标记、阴影属性)
1.必需和可选属性 如果实体属性可以包含null,则将其视为可选.如果属性的有效值不可以包含null,则将其视为必需属性.映射到关系数据库架构时,必需的属性将创建为不可为null的列,而可选属性则创建 ...
- 基于Spring Boot的统一异常处理设计
基于Spring Boot的统一异常处理设计 作者: Grey 原文地址:https://www.cnblogs.com/greyzeng/p/11733327.html Spring Boot中,支 ...