.NET3.5中JSON用法以及封装JsonUtils工具类
.NET3.5中JSON用法以及封装JsonUtils工具类
我们讲到JSON的简单使用,现在我们来研究如何进行封装微软提供的JSON基类,达到更加方便、简单、强大且重用性高的效果。
首先创建一个类JsonUtils.cs,代码如下:
JsonUtils代码,点击展开
using System.Net;
using System.Reflection;
using System.Collections;
using System.Collections.Generic;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Ink;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using System.Json;
namespace SLCommon
{
public class JsonUtils
{
/// <summary>
/// 将JSON文本反序列化成List<T>对象
/// </summary>
/// <typeparam name="T">泛型类,实体类型</typeparam>
/// <param name="jsonString">JSON文本</param>
/// <returns>返回List<T>对象</returns>
public static List<T> toList<T>(String jsonString) where T : new()
{
JsonArray jsonArray = JsonArray.Parse(jsonString) as JsonArray;
return toList<T>(jsonArray);
}
/// <summary>
/// 将JsonArray对象转化成List<T>对象
/// </summary>
/// <typeparam name="T">泛型类,实体类型</typeparam>
/// <param name="jsonArray">传入的参数JsonArray对象</param>
/// <returns>返回List<T>对象</returns>
public static List<T> toList<T>(JsonArray jsonArray) where T : new()
{
//申明泛型List
List<T> entityList = new List<T>();
//获取泛型类的类型
Type classType = new T().GetType();
//获取泛型类中的属性信息
PropertyInfo[] propertys =
foreach (JsonObject jsonObject in jsonArray)
{
//创建泛型对象
T entity = new T();
//遍历属性数组
foreach (PropertyInfo property in propertys)
{
//得到类中属性的数据类型
var type = property.PropertyType.FullName;
//通过属性名称prperty.Name在jsonObject中检索到相应的值
var val = JsonTypeUtils.TypeConvert(jsonObject[property.Name]);
//数据类型转换
var value = TypeUtils.ConvertType(type, val);
//将属性值赋值给相应的属性
property.SetValue(entity, value, null);
}
//泛型类对象放入List中
entityList.Add(entity);
}
return entityList;
}
/// <summary>
/// 将JSON文本反序列化成实体类对象
/// </summary>
/// <typeparam name="T">泛型类,实体类型</typeparam>
/// <param name="jsonString">JSON文本</param>
/// <returns>返回泛型T类型实体对象</returns>
public static T toEntity<T>(String jsonString) where T : new()
{
JsonObject jsonObject = JsonObject.Parse(jsonString) as JsonObject;
return toEntity<T>(jsonObject);
}
/// <summary>
/// 将JSON对象转化成实体类对象
/// </summary>
/// <typeparam name="T">泛型类,实体类型</typeparam>
/// <param name="jsonObject">JSON对象</param>
/// <returns>返回泛型T类型实体对象</returns>
public static T toEntity<T>(JsonObject jsonObject) where T : new()
{
//创建泛型对象
T entity = new T();
//获取泛型类的类型
Type classType = entity.GetType();
//获取泛型类中的属性信息
PropertyInfo[] propertys =
//遍历属性数组
foreach (PropertyInfo property in propertys)
{
//得到类中属性的数据类型
var type = property.PropertyType.FullName;
//通过属性名称prperty.Name在jsonObject中检索到相应的值
var val = JsonTypeUtils.TypeConvert(jsonObject[property.Name]);
//数据类型转换
var value = TypeUtils.ConvertType(type, val);
//将属性值赋值给相应的属性
property.SetValue(entity, value, null);
}
return entity;
}
}
}
在上面用到了2个辅助类,因为从JsonObject中取到值后,值的数据类型是JsonValue,并非普通的数据类型,在利用反射为类的属性赋值的时候不能识别JsonValue中的数据类型,不能实现数据类型的隐式转换。但它有自己的数据类型如下:
JsonType枚举:
JsonType.Array
JsonType.Boolean
JsonType.Number
JsonType.Object
JsonType.String
我们先通过JsonTypeUtils类来实现JsonType中的数据类型与基本数据类型之间的转换,代码如下:
JsonTypeUtils代码,点击展开
using System.Net;
using System.Numeric;
using System.Linq;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Ink;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using System.Json;
namespace SLCommon
{
public class JsonTypeUtils
{
public static Object TypeConvert(JsonValue jv)
{
if(jv.JsonType == JsonType.Array)
{
return new JsonArray(jv);
}
if (jv.JsonType == JsonType.Boolean)
{
return Boolean.Parse(jv.ToString());
}
if (jv.JsonType == JsonType.Number)
{
return Double.Parse(jv.ToString());
}
if (jv.JsonType == JsonType.Object)
{
return (Object)jv;
}
if (jv.JsonType == JsonType.String)
{
return jv.ToString();
}
return jv;
}
}
}
这时获取到的数据类型只是根据上面5种枚举类型转换的,得到的值并非属性真正的类型,所以需要通过先获取类中属性的数据类型:
var type = property.PropertyType.FullName;
然后通过TypeUtils类的静态方法ConvertType类实现把值转换到属性的类型,代码如下:
TypeUtils代码,点击展开
val = s;
break;
case "System.Int16":
case "System.Int32":
case "System.Int64":
val = int.Parse(value.ToString());
break;
case "System.Double":
val = Double.Parse(value.ToString());
break;
case "System.Decimal":
val = Decimal.Parse(value.ToString());
break;
case "System.Object":
val = (Object)value;
break;
}
return val;
}
}
}
在TypeUtils中还只实现了少数数据类型的转换,还有待完善。
下面介绍JsonUtils的用法,先创建实体类FruitEntity.cs,代码如下:
FruitEntity代码,点击展开
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace SLEntity
{
public class FruitEntity
{
private String id;
private String name;
private Double price;
private Double stock;
private String date;
public String Id
{
get { return id; }
set { id = value; }
}
public String Name
{
get { return name; }
set { name = value; }
}
public Double Price
{
get { return price; }
set { price = value; }
}
public Double Stock
{
get { return stock; }
set { stock = value; }
}
public String Date
{
get { return date; }
set { date = value; }
}
}
}
JsonUtils用法示例代码:
JsonUtils用法代码
//上面JSON文本为一个对象,不是多个对象组成的数组。所以转换为实体类:
FruitEntity entity = JsonUtils.toEntity<FruitEntity>(jsonStr);
.NET3.5中JSON用法以及封装JsonUtils工具类的更多相关文章
- JAVA中封装JSONUtils工具类及使用
在JAVA中用json-lib-2.3-jdk15.jar包中提供了JSONObject和JSONArray基类,用于JSON的序列化和反序列化的操作.但是我们更习惯将其进一步封装,达到更好的重用. ...
- 在JAVA中封装JSONUtils工具类及使用 (转)
import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; import java.util. ...
- 转:轻松把玩HttpClient之封装HttpClient工具类(一)(现有网上分享中的最强大的工具类)
搜了一下网络上别人封装的HttpClient,大部分特别简单,有一些看起来比较高级,但是用起来都不怎么好用.调用关系不清楚,结构有点混乱.所以也就萌生了自己封装HttpClient工具类的想法.要做就 ...
- writeValueAsString封装成工具类
封装成工具类 <span style="font-family:Microsoft YaHei;">public static String toJsonByObjec ...
- 打印 Logger 日志时,需不需要再封装一下工具类?
在开发过程中,打印日志是必不可少的,因为日志关乎于应用的问题排查.应用监控等.现在打印日志一般都是使用 slf4j,因为使用日志门面,有助于打印方式统一,即使后面更换日志框架,也非常方便.在 < ...
- MySQL数据库学习笔记(十一)----DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- MySQL JDBC事务处理、封装JDBC工具类
MySQL数据库学习笔记(十)----JDBC事务处理.封装JDBC工具类 一.JDBC事务处理: 我们已经知道,事务的概念即:所有的操作要么同时成功,要么同时失败.在MySQL中提供了Commit. ...
- DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)
DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类) 一.DAO模式简介 DAO即Data Access Object,数据访问接口.数据访问:故名思义就是与数据库打交道.夹在业务逻辑与数据 ...
随机推荐
- Python Scopes and Namespaces
Before introducing classes, I first have to tell you something about Python's scope rules. Class def ...
- MVC的过滤器
过滤器分类: Action过滤器 View结果渲染过滤器 全局错误异常过滤器 身份验证过滤器 1.Action过滤器:在Action执行之前和执行之后分别干一些事 接口:(IA ...
- bigworld源码分析(5)——BaseApp分析
BaseApp负载部分,核心代码缺失...网上的源码中都找不到,暂时没办法分析其核心内容,很遗憾,继续寻找吧,等找到了,再继续自己的分析.
- raw_input 和input的区别
input它会根据用户输入变换相应的类型, raw_input则是不管用户输入什么类型的都会转变成字符型.
- LeetCode 【47. Permutations II】
Given a collection of numbers that might contain duplicates, return all possible unique permutations ...
- Apache配置代理服务器的方法(2)
Proxy指令后面的*号表示客户端使用代理服务器访问的目的地址.在上面两个例子中,*号表示所有地址,即禁止使用代理服务器访问所有地址.而如果想仅禁止某一些地址时,可以参考下面的例子: Order de ...
- gdb使用心得
启用调试gdb gdb 路径到prog_1dray 然后就直接进去gdb了 进去后输入r *.par 参数文件就行了 暂时学到这,用到这!日后再学习更新
- libtcc使用问题一二
问题来由: powersniff(参考博客的文章,在qq群下载最新版本)目前使用lua作为分析插件,但熟练lua的人不多.所以,移植python和tcc两类语言作为插件. tcc(即tiny c),h ...
- DataItem,gridview,repeater数据控件数据绑定
Container.DataItem几种方式. 在绑定数据时经常会用到这个句程序:<%# DataBinder.Eval(Container.DataItem,"xxxx") ...
- mybatis 使用记录
首先,贴一个好文.把mybatis中的<if></if>的条件扒到源码分析了一遍.PS:目前还看不懂... http://cheng-xinwei.iteye.com/blog ...