• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

asp.net JSONHelper JSON帮助类

asp 搞代码 4年前 (2022-01-03) 27次浏览 已收录 0个评论

asp.net JSONHelper JSON帮助类

代码如下:
/**************************************************
* 版权所有: Mr_Sheng
* 文 件 名: JSONHelper.cs
* 文件描述:
* 类型说明: JSONHelper JSON帮助类
* 授权声明:
* 本程序为自由软件;
* 您可依据自由软件基金会所发表的GPL v3授权条款,对本程序再次发布和/或修改;
* 本程序是基于使用目的而加以发布,然而不负任何担保责任;
* 亦无对适售性或特定目的适用性所为的默示性担保。
* 详情请参照GNU通用公共授权 v3(参见license.txt文件)。
* 版本历史:
* v2.0.0 Mr_Sheng 2009-09-09 修改
***************************************************/
using System;
using System.Collections.Generic;
using System.Web;
using System.Web.Script.Serialization;
using System.Data;
namespace Sheng.Common
{
///

/// JSON帮助类
///

public class JSONHelper
{
///

/// 对象转JSON
///

/// 对象
/// JSON格式的字符串
public static string ObjectToJSON(object obj)
{
JavaScriptSerializer jss = new JavaScriptSerializer();
try
{
return jss.Serialize(obj);
}
catch (Exception ex)
{
throw new Exception(“JSONHelper.ObjectToJSON(): ” + ex.Message);
}
}
///

/// 数据表转键值对集合
/// 把DataTable转成 List集合, 存每一行
/// 集合中放的是键值对字典,存每一列
///

/// 数据表
/// 哈希表数组
public static List<Dictionary> DataTableToList(DataTable dt)
{
List<Dictionary> list
= new List<Dictionary>();
foreach (DataRow dr in dt.Rows)来源gao*daima.com搞@代#码网
{
Dictionary dic = new Dictionary();
foreach (DataColumn dc in dt.Columns)
{
dic.Add(dc.ColumnName, dr[dc.ColumnName]);
}
list.Add(dic);
}
return list;
}
///

/// 数据集转键值对数组字典
///

/// 数据集
/// 键值对数组字典
public static Dictionary<string, List<Dictionary>> DataSetToDic(DataSet ds)
{
Dictionary<string, List<Dictionary>> result = new Dictionary<string, List<Dictionary>>();
foreach (DataTable dt in ds.Tables)
result.Add(dt.TableName, DataTableToList(dt));
return result;
}
///

/// 数据表转JSON
///

/// 数据表
/// JSON字符串
public static string DataTableToJSON(DataTable dt)
{
return ObjectToJSON(DataTableToList(dt));
}
///

/// JSON文本转对象,泛型方法
///

/// 类型
/// JSON文本
/// 指定类型的对象
public static T JSONToObject(string jsonText)
{
JavaScriptSerializer jss = new JavaScriptSerializer();
try
{
return jss.Deserialize(jsonText);
}
catch (Exception ex)
{
throw new Exception(“JSONHelper.JSONToObject(): ” + ex.Message);
}
}
///

/// 将JSON文本转换为数据表数据
///

/// JSON文本
/// 数据表字典
public static Dictionary<string, List<Dictionary>> TablesDataFromJSON(string jsonText)
{
return JSONToObject<Dictionary<string, List<Dictionary>>>(jsonText);
}
///

/// 将JSON文本转换成数据行
///

/// JSON文本
/// 数据行的字典
public static Dictionary DataRowFromJSON(string jsonText)
{
return JSONToObject<Dictionary>(jsonText);
}
}
}

System.Web.Script.Serialization命名空间是.Net 3.5新添加的.
如果要在3.5以下版本中使用,可以下载3.5中的System.Web.Extensions.dll 引入到自己的应用中.

以上就是asp.net JSONHelper JSON帮助类的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:asp.net JSONHelper JSON帮助类

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址