1.引用Newtonsoft.Json库(JSON.NET)。

2.复制粘贴JsonHelper吧。

源代码:

using System;
using System.Collections.Generic;
using System.Linq;
using Newtonsoft.Json;
using Newtonsoft.Json.Converters; namespace Allen.Core
{
public static partial class JsonHelper
{
#region Private fields private static readonly JsonSerializerSettings JsonSettings; private const string EmptyJson = "[]";
#endregion #region Constructor static JsonHelper()
{
var datetimeConverter = new IsoDateTimeConverter { DateTimeFormat = "yyyy-MM-dd HH:mm:ss" }; JsonSettings = new JsonSerializerSettings
{
MissingMemberHandling = MissingMemberHandling.Ignore,
NullValueHandling = NullValueHandling.Ignore,
ReferenceLoopHandling = ReferenceLoopHandling.Ignore
};
JsonSettings.Converters.Add(datetimeConverter);
}
#endregion #region Public Methods /// <summary>
/// 应用Formatting.None和指定的JsonSerializerSettings设置,序列化对象到JSON格式的字符串
/// </summary>
/// <param name="obj">任意一个对象</param>
/// <param name="jsonSettings">在一个 Newtonsoft.Json.JsonSerializer 对象上指定设置,如果为null,则使用默认设置</param>
/// <returns>标准的JSON格式的字符串</returns>
public static string ToJson(object obj, JsonSerializerSettings jsonSettings)
{
return ToJson(obj, Formatting.None, jsonSettings);
} /// <summary>
/// 应用指定的Formatting枚举值None和指定的JsonSerializerSettings设置,序列化对象到JSON格式的字符串
/// </summary>
/// <param name="obj">任意一个对象</param>
/// <param name="format">指定 Newtonsoft.Json.JsonTextWriter 的格式设置选项</param>
/// <param name="jsonSettings">在一个 Newtonsoft.Json.JsonSerializer 对象上指定设置,如果为null,则使用默认设置</param>
/// <returns>标准的JSON格式的字符串</returns>
public static string ToJson(object obj, Formatting format, JsonSerializerSettings jsonSettings)
{
try
{
return obj == null ? EmptyJson : JsonConvert.SerializeObject(obj, format, jsonSettings ?? JsonSettings);
}
catch (Exception)
{
//TODO LOG
return EmptyJson;
}
} /// <summary>
/// 应用Formatting.None和指定的JsonSerializerSettings设置,反序列化JSON数据为dynamic对象
/// <para>如果发生JsonSerializationException异常,再以集合的方式重试一次,取出集合的第一个dynamic对象。</para>
/// <para>转换失败,或发生其它异常,则返回dynamic对象的默认值</para>
/// </summary>
/// <param name="json">需要反序列化的JSON字符串</param>
/// <param name="jsonSettings">在一个 Newtonsoft.Json.JsonSerializer 对象上指定设置,如果为null,则使用默认设置</param>
/// <returns>dynamic对象</returns>
public static dynamic FromJson(this string json, JsonSerializerSettings jsonSettings)
{
return FromJson<dynamic>(json, Formatting.None, jsonSettings);
} /// <summary>
/// 应用指定的Formatting枚举值None和指定的JsonSerializerSettings设置,反序列化JSON数据为dynamic对象
/// <para>如果发生JsonSerializationException异常,再以集合的方式重试一次,取出集合的第一个dynamic对象。</para>
/// <para>转换失败,或发生其它异常,则返回dynamic对象的默认值</para>
/// </summary>
/// <param name="json">需要反序列化的JSON字符串</param>
/// <param name="format">指定 Newtonsoft.Json.JsonTextWriter 的格式设置选项</param>
/// <param name="jsonSettings">在一个 Newtonsoft.Json.JsonSerializer 对象上指定设置,如果为null,则使用默认设置</param>
/// <returns>dynamic对象</returns>
public static dynamic FromJson(this string json, Formatting format, JsonSerializerSettings jsonSettings)
{
return FromJson<dynamic>(json, format, jsonSettings);
} /// <summary>
/// 应用Formatting.None和指定的JsonSerializerSettings设置,反序列化JSON数据到指定的.NET类型对象
/// <para>如果发生JsonSerializationException异常,再以集合的方式重试一次,取出集合的第一个T对象。</para>
/// <para>转换失败,或发生其它异常,则返回T对象的默认值</para>
/// </summary>
/// <param name="json">需要反序列化的JSON字符串</param>
/// <param name="jsonSettings">在一个 Newtonsoft.Json.JsonSerializer 对象上指定设置,如果为null,则使用默认设置</param>
/// <typeparam name="T">反序列化对象的类型</typeparam>
/// <returns></returns>
public static T FromJson<T>(string json, JsonSerializerSettings jsonSettings) where T : class, new()
{
return FromJson<T>(json, Formatting.None, jsonSettings);
} /// <summary>
/// 应用指定的Formatting枚举值None和指定的JsonSerializerSettings设置,反序列化JSON数据到指定的.NET类型对象
/// <para>如果发生JsonSerializationException异常,再以集合的方式重试一次,取出集合的第一个T对象。</para>
/// <para>转换失败,或发生其它异常,则返回T对象的默认值</para>
/// </summary>
/// <param name="json">需要反序列化的JSON字符串</param>
/// <param name="format">指定 Newtonsoft.Json.JsonTextWriter 的格式设置选项</param>
/// <param name="jsonSettings">在一个 Newtonsoft.Json.JsonSerializer 对象上指定设置,如果为null,则使用默认设置</param>
/// <typeparam name="T">反序列化对象的类型</typeparam>
/// <returns></returns>
public static T FromJson<T>(string json, Formatting format, JsonSerializerSettings jsonSettings) where T : class, new()
{
T result; if (jsonSettings == null)
{
jsonSettings = JsonSettings;
} try
{
result = string.IsNullOrWhiteSpace(json) ? default(T) : JsonConvert.DeserializeObject<T>(json, jsonSettings);
}
catch (JsonSerializationException) //在发生该异常后,再以集合的方式重试一次.
{
//LOG
try
{
var array = JsonConvert.DeserializeObject<IEnumerable<T>>(json, jsonSettings);
result = array.FirstOrDefault();
}
catch (Exception)
{
//LOG
result = default(T);
}
}
catch (Exception)
{
//LOG
result = default(T);
}
return result;
}
#endregion #region Public Extend Methods /// <summary>
/// 反序列化JSON数据为dynamic对象
/// <para>如果发生JsonSerializationException异常,再以集合的方式重试一次,取出集合的第一个dynamic对象。</para>
/// <para>转换失败,或发生其它异常,则返回dynamic对象的默认值</para>
/// </summary>
/// <param name="json">需要反序列化的JSON字符串</param>
/// <returns>dynamic对象</returns>
public static dynamic FromJson(this string json)
{
return FromJson<dynamic>(json, Formatting.None, JsonSettings);
} /// <summary>
/// 反序列化JSON数据到指定的.NET类型对象
/// <para>如果发生JsonSerializationException异常,再以集合的方式重试一次,取出集合的第一个T对象。</para>
/// <para>转换失败,或发生其它异常,则返回T对象的默认值</para>
/// </summary>
/// <param name="json">需要反序列化的JSON字符串</param>
/// <typeparam name="T">反序列化对象的类型</typeparam>
/// <returns></returns>
public static T FromJson<T>(this string json) where T : class, new()
{
return FromJson<T>(json, Formatting.None, JsonSettings);
} /// <summary>
/// 应用默认的Formatting枚举值None和默认的JsonSerializerSettings设置,序列化对象到JSON格式的字符串
/// </summary>
/// <param name="obj">任意一个对象</param>
/// <returns>标准的JSON格式的字符串</returns>
public static string ToJson(this object obj)
{
return ToJson(obj, Formatting.None, JsonSettings);
} public static string ToJson<TSource>(this IEnumerable<TSource> source, Func<TSource, bool> predicate, bool isFilterNull = true)
{
return DelegateToJson(source, enumerable => enumerable.Where(predicate), isFilterNull);
} public static string ToJson<TSource>(this IEnumerable<TSource> source, Func<TSource, int, bool> predicate, bool isFilterNull = true)
{
return DelegateToJson(source, enumerable => enumerable.Where(predicate), isFilterNull);
} public static string ToJson<TSource, TResult>(this IEnumerable<TSource> source, Func<TSource, TResult> selector, bool isFilterNull = true)
{
return DelegateToJson(source, enumerable => enumerable.Where(t => t != null).Select(selector), isFilterNull);
} public static string ToJson<TSource, TResult>(this IEnumerable<TSource> source, Func<TSource, int, TResult> selector, bool isFilterNull = true)
{
return DelegateToJson(source, enumerable => enumerable.Where(t => t != null).Select(selector), isFilterNull);
} public static string ToJson<TSource, TResult>(this IEnumerable<TSource> source, Func<TSource, bool> predicate, Func<TSource, TResult> selector, bool isFilterNull = true)
{
return DelegateToJson(source, enumerable => enumerable.Where(predicate).Select(selector), isFilterNull);
} public static string ToJson<TSource, TResult>(this IEnumerable<TSource> source, Func<TSource, bool> predicate, Func<TSource, int, TResult> selector, bool isFilterNull = true)
{
return DelegateToJson(source, enumerable => enumerable.Where(predicate).Select(selector), isFilterNull);
} public static string ToJson<TSource, TResult>(this IEnumerable<TSource> source, Func<TSource, int, bool> predicate, Func<TSource, TResult> selector, bool isFilterNull = true)
{
return DelegateToJson(source, enumerable => enumerable.Where(predicate).Select(selector), isFilterNull);
} public static string ToJson<TSource, TResult>(this IEnumerable<TSource> source, Func<TSource, int, bool> predicate, Func<TSource, int, TResult> selector, bool isFilterNull = true)
{
return DelegateToJson(source, enumerable => enumerable.Where(predicate).Select(selector), isFilterNull);
}
#endregion #region Private Methods /// <summary>
/// 委托处理需要序列化为JSON格式的对象,返回标准的JSON格式的字符串。
/// 默认过滤null对象,如果需要在上层调用时,自己进行条件过滤null对象,
/// 则设置isFilterNull为false,不建议isFilterNull设置为false。
/// </summary>
/// <typeparam name="TSource"></typeparam>
/// <typeparam name="TResult"></typeparam>
/// <param name="source">需要转换为JSON格式字符串的对象</param>
/// <param name="func">集合/数组条件筛选方法委托,返回筛选后的集合/数组</param>
/// <param name="isFilterNull">是否过滤IEnumerable<TSource> source中的null对象,默认为true</param>
/// <returns>标准的JSON格式的字符串</returns>
private static string DelegateToJson<TSource, TResult>(IEnumerable<TSource> source, Func<TSource[], IEnumerable<TResult>> func, bool isFilterNull = true)
{
return DelegateToJson(source, enumerable => func(enumerable).ToJson(), isFilterNull);
} /// <summary>
/// 委托处理需要序列化为JSON格式的对象,返回标准的JSON格式的字符串。
/// 默认过滤null对象,如果需要在上层调用时,自己进行条件过滤null对象,
/// 则设置isFilterNull为false,不建议isFilterNull设置为false。
/// </summary>
/// <typeparam name="TSource"></typeparam>
/// <param name="source">需要转换为JSON格式字符串的对象</param>
/// <param name="func">JSON处理方法委托,返回JSON格式的字符串</param>
/// <param name="isFilterNull">是否过滤IEnumerable<TSource> source中的null对象,默认为true</param>
/// <returns>标准的JSON格式的字符串</returns>
private static string DelegateToJson<TSource>(IEnumerable<TSource> source, Func<TSource[], string> func, bool isFilterNull = true)
{
if (source == null)
{
return EmptyJson;
} TSource[] enumerable;
if (isFilterNull)
{
//过滤null
enumerable = source.Where(t => t != null).ToArray();
}
else
{
//不过滤null,但上层需要注意内里面有null对象时,可能会导致Where或Select引发异常。
enumerable = source as TSource[] ?? source.ToArray();
} return enumerable.Any() ? func(enumerable) : EmptyJson;
} #endregion
}
}

用法案例:

class Program
{
static void Main(string[] args)
{
//ToJson 方法 Test
#region 默认过滤null对象 var list1 = new List<Test>
{
new Test {Id = 10, Type = 21, Name="Allen"},
new Test {Id = 11, Type = 22},
new Test {Id = 12, Type = 23},
new Test {Id = 13, Type = 24, Name="Peter"},
null,
new Test {Id = 13, Type = 24, Name=null}
}; //指定json数据所需要的属性
string jsonString = list1.ToJson(t => new { id = t.Id, type = t.Type }); //推荐写法,连true都省略掉
//string jsonString = JsonHelper.ToJson(list1, t => new { id = t.Id, type = t.Type }); //不推荐该写法
//string jsonString = list1.ToJson(t => new { id = t.Id, type = t.Type }, true);
Console.WriteLine(jsonString); //筛选出Name为"Allen"的对象
string jsonString2 = list1.ToJson(t => t.Name == "Allen"); //推荐写法,连true都省略掉
//string jsonString2 = JsonHelper.ToJson(list1, t => t.Name == "Allen"); //不推荐该写法
//string jsonString2 = list1.ToJson(t => t.Name == "Allen", true);
Console.WriteLine(jsonString2); //筛选出Name为"Allen"的对象,并且指定json数据所需要的属性
string jsonString3 = list1.ToJson(t => t.Name == "Allen", t => new { id = t.Id, type = t.Type }); //推荐写法,连true都省略掉
//string jsonString3 = JsonHelper.ToJson(list1, t => t.Name == "Allen", t => new { id = t.Id, type = t.Type }); //不推荐该写法
//string jsonString3 = list1.ToJson(t => t.Name == "Allen", t => new { id = t.Id, type = t.Type }, true);
Console.WriteLine(jsonString3);
#endregion #region 不过滤null对象 var list2 = new List<Test>
{
new Test {Id = 10, Type = 21, Name="Allen"},
new Test {Id = 11, Type = 22, Name="Bolong"},
new Test {Id = 12, Type = 23, Name="Popo"},
new Test {Id = 13, Type = 24, Name="Peter"},
new Test {Id = 16, Type = 25, Name="Willy"}
}; //指定json数据所需要的属性
string jsonString4 = list2.ToJson(t => new { id = t.Id, type = t.Type }, false);
Console.WriteLine(jsonString4); //筛选出Name为"Allen"的对象
string jsonString5 = list2.ToJson(t => t.Name == "Allen", false);
Console.WriteLine(jsonString5); //筛选出Name为"Allen"的对象,并且指定json数据所需要的属性
string jsonString6 = list2.ToJson(t => t.Name == "Allen", t => new { id = t.Id, type = t.Type }, false);
Console.WriteLine(jsonString6);
#endregion //FromJson<T> 方法 Test
List<Test> testList1 = jsonString.FromJson<List<Test>>();
List<Test> testList2 = jsonString2.FromJson<List<Test>>();
Test test = jsonString3.FromJson<Test>(); //弱类型 Test
var test2 = jsonString.FromJson();
Newtonsoft.Json.Linq.JArray test3 = test2; Console.ReadKey();
}
} internal class Test
{
public int Type { get; set; } public int Id { get; set; } public string Name { get; set; }
}

PS:有更好的封装建议吗?

JSON扩展类——JsonHelper的更多相关文章

  1. C# json帮助类,JsonHelper,Table转JSon,JSon转Table

    /// <summary> /// json帮助类 /// </summary> public class JsonHelper { public JsonHelper() { ...

  2. ASP.NET(C#) Json序列化反序列化帮助类Jsonhelper

    原文地址:https://ken.io/note/csharp-asp.net-jsonhelper using System; using System.Collections.Generic; u ...

  3. Thinkphp编辑器扩展类kindeditor用法

    一, 使用前的准备. 使用前请确认你已经建立好了一个Thinkphp站点项目. 1,Keditor.class.php和JSON.class.php 是编辑器扩展类文件,将他们拷贝到你的站点项目的Th ...

  4. Spring统一返回Json工具类,带分页信息

    前言: 项目做前后端分离时,我们会经常提供Json数据给前端,如果有一个统一的Json格式返回工具类,那么将大大提高开发效率和减低沟通成本. 此Json响应工具类,支持带分页信息,支持泛型,支持Htt ...

  5. C#封装的一个JSON操作类

    using System; using System.Collections.Generic; using System.Collections; using System.Text; using S ...

  6. UI(UGUI)框架(二)-------------UIManager单例模式与开发BasePanel面板基类/UIManage统一管理UI面板的实例化/开发字典扩展类

    UIManage单实例: /// 单例模式的核心 /// 1,定义一个静态的对象 在外界访问 在内部构造 /// 2,构造方法私有化 private static UIManager _instanc ...

  7. Android Json转换类对象,并使用

    长话短说,先上代码(今天的代码是有史以来最短的)(今天的课也是有史以来最精简...) 然后就是介绍Song是啥,上面的网站应该知道,是网易云的,不过为啥会变成这样,因为这是网易云的API网站 反正就是 ...

  8. [No00009A]JsonToObject json与类互转

    using System.Web.Script.Serialization; /// <summary> /// 内部类,保存jsonData /// </summary> p ...

  9. C# 扩展类

    C# 中提供一个非常实用的供能,扩展方法(Extension method) 扩展方法是通过额外的静态方法扩展现有的类型.通过扩展方法,可以对已有类型做自己想做的相关扩展.方法:定义静态类,扩展方法也 ...

随机推荐

  1. [C#] 简单的 Helper 封装 -- RandomHelper

    using System; namespace Wen.Helpers { /// <summary> /// 随机数助手 /// </summary> public seal ...

  2. Redis的简单动态字符串实现

    Redis 没有直接使用 C 语言传统的字符串表示(以空字符结尾的字符数组,以下简称 C 字符串), 而是自己构建了一种名为简单动态字符串(simple dynamic string,sds)的抽象类 ...

  3. 《JavaScript设计模式与开发实践》整理

    最近在研读一本书<JavaScript设计模式与开发实践>,进阶用的. 一.高阶函数 高阶函数是指至少满足下列条件之一的函数. 1. 函数可以作为参数被传递. 2. 函数可以作为返回值输出 ...

  4. javascript动画系列第四篇——拖拽改变元素大小

    × 目录 [1]原理简介 [2]范围圈定 [3]大小改变[4]代码优化 前面的话 拖拽可以让元素移动,也可以改变元素大小.本文将详细介绍拖拽改变元素大小的效果实现 原理简介 拖拽让元素移动,是改变定位 ...

  5. 关于DDD的学习资料汇总

    DDD(Domain-Driven Design)领域驱动设计,第一次看到DDD是在学习ABP时,在其中的介绍中看到的.what,DDD是个什么鬼,我不是小白,是大白,没听过.于是乎,度娘查查查,找到 ...

  6. css中line-height行高的深入学习

    之前对css中行高line-height的理解还是有些肤浅,深入后才发觉里面包罗万象.学习行高line-height,首先从基本原理开始 (标注该文章转载 http://www.cnblogs.com ...

  7. BPM嵌入式流程解决方案分享

    一.需求分析由于企业业务的独特性或者企业高层独特的管理思想,很多客户选择了自行开发业务系统的方式来实现独有的竞争力. 这类信息系统通常经过了多年的开发,伴随着企业的发展一直在不断优化,与企业的业务非常 ...

  8. Eclipse出现"Running Android Lint has encountered a problem"解决方案

    安装eclipse for android 时候的错误记录,转载自:http://blog.csdn.net/chenyufeng1991/article/details/47442555 (1)打开 ...

  9. Android中的沉浸式状态栏效果

    无意间了解到沉浸式状态栏,感觉贼拉的高大上,于是就是试着去了解一下,就有了这篇文章.下面就来了解一下啥叫沉浸式状态栏.传统的手机状态栏是呈现出黑色条状的,有的和手机主界面有很明显的区别.这一样就在一定 ...

  10. 使用Jenkins配置Git+Maven的自动化构建

    Jenkins是一个开源的持续集成工具,应用Jenkins搭建持续集成环境,可以进行自动构建.自动编译和部署,非常方便. 在服务器比较少的情况下,Jenkins的优势并不明显,但是随着项目发展,服务器 ...