通用JSONHelp 的通用的封装
1. 最近项目已经上线了 ,闲暇了几天 想将JSON 的序列化 以及反序列化进行重新的封装一下本人定义为JSONHelp,虽然Microsoft 已经做的很好了。但是我想封装一套为自己开发的项目使用。方便后期的扩展以及开发使用。
2. 什么是 JSON ?
JSON:JavaScript 对象表示法(JavaScript Object Notation)。JSON 是存储和交换文本信息的语法。类似 XML。JSON 比 XML 更小、更快,更易解析。 现在开发Web应用程序 JSON 是 必不可少的。JSON 是轻量级的文本数据交换格 ,JSON 独立于语言 ,JSON 具有自我描述性,更易理解 ,JSON 使用 JavaScript 语法来描述数据对象,但是 JSON 仍然独立于语言和平台。JSON 解析器和 JSON 库支持许多不同的编程语言。
3.JSON - 转换为 JavaScript 对象
JSON 文本格式在语法上与创建 JavaScript 对象的代码相同。由于这种相似性,无需解析器,JavaScript 程序能够使用内建的 eval() 函数 ,用 JSON 数据来生成原生的 JavaScript 对象。
4.类似 XML
JSON 是纯文 JSON 具有 自我描述的特性 , JSON 具有层级结构(值中存在值) JSON 可通过 JavaScript 进行解析 JSON 数据可使用 AJAX 进行传输 相比 XML 的不同之处 没有结束标签更短 读写的速度更快 能够使用内建的 ,JavaScript eval() 方法进行解析 , 使用数组 ,不使用保留字
5.为什么使用 JSON?
对于 AJAX 应用程序来说,JSON 比 XML 更快更易使用: 使用 XML 读取 XML 文档 使用 XML DOM 来循环遍历文档 读取值并存储在变量中
6. 使用 JSON
读取 JSON 字符串 用 eval() 处理 JSON 字符串 前端JS 界面我们通常使用、JSON.parse() 进行将对象或者数组字符串进行序列化进行JSON 对象 与JSON.stringify()
7. JSON 的序列化 以及反序列化
JSON 的序列化 和反序列化 我用using Newtonsoft.Json 之中的JsonConvert.SerializeObject() 和using System.Runtime.Serialization.Json; 之中的Jil.JSON.Serialize()
当然这2个序列化的方式是相同的。但是Jil.JSON.Serialize() 序列化的效率确实比这个JsonConvert.SerializeObject() 高的多了。在大量的数据的序列化的时候 明显是可以看的出来的。所以
我建议当序列化 以及反序列化 数据量非常大而且多的时候 强烈建议使用Jil.JSON.Serialize() 来进行序列化对象 以及反序列化对象等等。
9.JSONHelp.cs 代码如下:
using Newtonsoft.Json;
using System;
using System.IO;
using System.Runtime.Serialization.Json;
using System.Text;
/************************************************
◇作者: LowKeyTranscend
◇说明: 通用管理里面的JSON的 序列化 和反序列化
◇版本号:V1.0
◇创建日期:2017年6月22日 星期四
*****************************************************/
namespace RapidDevelopmentFramework.Common
{
/// <summary>
/// JSON辅助类
/// </summary>
public static class JSONHelper
{
/// <summary>
/// JSON 序列化的普通版本
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="_Object"></param>
/// <returns></returns>
public static String ObjectToJSON<T>(this T _Object) where T :class
{
return JsonConvert.SerializeObject(_Object);
}
/// <summary>
/// JSON 序列化的标准版本
/// </summary>
/// <param name="_Object"></param>
/// <returns></returns>
public static String ObjectToJSON(this Object _Object)
{
return JsonConvert.SerializeObject(_Object);
}
/// <summary>
/// JSON 序列化的官方版本
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="_Object"></param>
/// <returns></returns>
public static String ObjectToJSONOfficial<T>(this T _Object) where T :class
{
using (var TempMemoryStream = new MemoryStream())
{
var MyDataContractJsonSerializer = new DataContractJsonSerializer(typeof(T));
MyDataContractJsonSerializer.WriteObject(TempMemoryStream, _Object);
var MySerializationString = Encoding.UTF8.GetString(TempMemoryStream.ToArray());
return MySerializationString;
}
}
/// <summary>
///JSON 序列化的Jil 版本
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="_Object"></param>
/// <returns></returns>
public static String ObjectToJSONJil<T>(this T _Object) where T :class
{
return Jil.JSON.Serialize(_Object, Jil.Options.ExcludeNullsIncludeInherited);
}
/// <summary>
/// JSON 序列化的Jil版本 可以包含null
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="_Object"></param>
/// <returns></returns>
public static String ObjectToJSONJilIncludeNulls<T>(this T _Object) where T:class
{
return Jil.JSON.Serialize(_Object, Jil.Options.IncludeInherited);
}
/// <summary>
/// JSON 的反序列化
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="_JSONString"></param>
/// <returns></returns>
public static T JSONToObjectJSON<T>(this String _JSONString) where T:class
{
return JsonConvert.DeserializeObject<T>(_JSONString);
}
/// <summary>
/// JSON的反序列化的官方版本
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="_JSONString"></param>
/// <returns></returns>
public static T JSONToObjectOfficial<T>(this String _JSONString) where T :class
{
using (var TempMemoryStream = new MemoryStream(Encoding.UTF8.GetBytes(_JSONString)))
{
var MyDataContractJsonSerializer = new DataContractJsonSerializer(typeof(T));
return (T)MyDataContractJsonSerializer.ReadObject(TempMemoryStream);
}
}
/// <summary>
/// JSON 的反序列化的官方版本
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="_JSONString"></param>
/// <returns></returns>
public static T JSONToObjectJil<T>(this String _JSONString) where T :class
{
using (var InputString = new StringReader(_JSONString))
{
var ObjectResult = Jil.JSON.Deserialize<T>(InputString);
return ObjectResult;
}
}
/// <summary>
/// JSON 的反序列化的Jil 版本 其中可以包含null
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="_JSONString"></param>
/// <returns></returns>
public static T JSONToObjectJilIncludeNulls<T>(this String _JSONString) where T :class
{
using (var InputString = new StringReader(_JSONString))
{
var ObjectResult = Jil.JSON.Deserialize<T>(InputString, Jil.Options.IncludeInherited);
return ObjectResult;
}
}
}
}
以上 内容全部是基于原创 部分观点以及理论引用了百度百科,如需转载请标明谢谢!!!
通用JSONHelp 的通用的封装的更多相关文章
- 关于EF 通用增删改查的封装
1. Entity Framework是Microsoft的ORM框架,随着 Entity Framework 不断的完善强化已经到达了EF 6.0+ 还是非常的完善的,目前使用的比例相对于其他OR ...
- 使用mybatis完成通用dao和通用service
使用mybatis完成通用dao和通用service 概述: 使用通用dao和通用service可以减少代码的开发.可以将常用的增删改查放到通用dao中.对不同的or框架,基本上都有自己的实现如Spr ...
- 基于Extjs 4.2的通用权限管理系统,通用后台模板,EF+MVC+Extjs 4.2
基于Extjs 4.2的通用权限管理系统,通用后台. 我们的宗旨:珍爱生命,拒绝重复!Don't Repeat Yourself!!! 本案例采用EntityFramework+MVC4.0+Extj ...
- 我的一个PLSQL函数 先查询再插入数据库的函数 动态SQL拼接查询条件、通用游标、记录定义(封装部分查询字段并赋值给游标)、insert select 序列、常量【我】
先查询再插入数据库的函数 CREATE OR REPLACE FUNCTION F_REVENUE_SI(l_p_cd in Varchar2, l_c_cd in Varchar2, l_prod_ ...
- ASP.NET 让无码编程不在是梦 -.NET通用平台、通用权限、易扩展、多语言、多平台架构框架
先拿出我半前年前平台的设计初稿,经过半年的努力我已经完成了该设计稿的所有功能.并且理念已经远远超出该设计稿. 下面是一些博友对我贴子的评价: 1.楼主,想法很美好,现实很骨感,我们公司就有一套你说的这 ...
- [Unity插件]Lua行为树(十):通用行为和通用条件节点
在行为树中,需要扩展的主要是行为节点和条件节点.一般来说,每当要创建一个节点时,就要新建一个节点文件.而对于一些简单的行为节点和条件节点,为了去掉新建文件的过程,可以写一个通用版本的行为节点和条件节点 ...
- 转-封装网络请求库,统一处理通用异常 (基于volley网络请求库)
http://blog.csdn.net/kroclin/article/details/40540761 一.前言 volley的发布让网络请求也变得十分便利,但是我们通常懒得很想用一两句代码实现一 ...
- jQuery Ajax通用js封装
第一步:引入jQuery库 <script type="text/javascript" src="<%=path%>/resources/js/jqu ...
- 基于封装通用的EF CRUD 的操作
1. Entity Framework是Microsoft的ORM框架,随着 Entity Framework 不断的完善强化已经到达了EF 6.0+ 还是非常的完善的,目前使用的比例相对于其他OR ...
随机推荐
- OpenStack云平台的网络模式及其工作机制
网络,是OpenStack的部署中最容易出问题的,也是其结构中难以理清的部分.经常收到关于OneStack部署网络方面问题和OpenStack网络结构问题的邮件.下面根据自己的理解,谈一谈OpenSt ...
- cuda学习2-block与thread数量的选取
由上一节可知,在main函数中,cuda程序的并行能力是在add<<<N,1>>>( dev_a, dev_b, dev_c )函数中体现的,这里面设置的是由N个b ...
- jQuery杂项方法
前面的话 杂项方法其实也是工具类方法,但由于其不是定义在jQuery构造函数上的方法,所以不能称为工具方法.本文将详细介绍jQuery中的杂项方法 数据操作 [data()] 该方法用于在匹配元素上存 ...
- 开发Activity步骤
第一步:写一个累继承Activity第二步:重写onCreate方法第三步:在主配置文件中注册activity <activity android:name=".类名" an ...
- lucene全文搜索之三:生成索引字段,创建索引文档(给索引字段加权)基于lucene5.5.3
前言:上一章中我们已经实现了索引器的创建,但是我们没有索引文档,本章将会讲解如何生成字段.创建索引文档,给字段加权以及保存文档到索引器目录 luncene5.5.3集合jar包下载地址:http:// ...
- 搭建rtmp直播流服务之4:videojs和ckPlayer开源播放器二次开发(播放rtmp、hls直播流及普通视频)
前面几章讲解了使用 nginx-rtmp搭建直播流媒体服务器; ffmpeg推流到nginx-rtmp服务器; java通过命令行调用ffmpeg实现推流服务; 从数据源获取,到使用ffmpeg推流, ...
- echarts仪表盘如何设置图例(legend)
echarts 图表中经常需要对不同的颜色设置图例标识不同的意义,而仪表盘的指针只存在一个值,如何表示不同颜色的意义,官网配置项并未给出该功能: 不同段的颜色是通过axisLine->lineS ...
- caffe源码学习之Proto数据格式【1】
前言: 由于业务需要,接触caffe已经有接近半年,一直忙着阅读各种论文,重现大大小小的模型. 期间也总结过一些caffe源码学习笔记,断断续续,这次打算系统的记录一下caffe源码学习笔记,巩固一下 ...
- Deep Q-Network 学习笔记(二)—— Q-Learning与神经网络结合使用(有代码实现)
参考资料: https://morvanzhou.github.io/ 非常感谢莫烦老师的教程 http://mnemstudio.org/path-finding-q-learning-tutori ...
- node.js零基础详细教程(7):node.js操作mongodb,及操作方法的封装
第七章 建议学习时间4小时 课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...