1.JSON的序列化和反序列化

Newtonsoft.Json dll 下载地址http://json.codeplex.com/

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Newtonsoft.Json; namespace PlayJSON
{
class Program
{
static void Main(string[] args)
{
List<StuInfo> list = new List<StuInfo>() { new StuInfo{StuName="张三",StuSex="男",StuAge=11},
new StuInfo{StuName="李四",StuSex="男",StuAge=32},
new StuInfo{StuName="王翠花",StuSex="女",StuAge=64}
};
string jsonStr = JavaScriptConvert.SerializeObject(list); //将对象转换成json存储
Console.WriteLine("JSON字符串"+jsonStr);
Console.ReadLine(); List<StuInfo> newList = new List<StuInfo>(); newList = (List<StuInfo>)JavaScriptConvert.DeserializeObject(jsonStr,typeof(List<StuInfo>)); //反序列化 //StuInfo s = new StuInfo() { StuName = "阿龙", StuSex = "男", StuAge = 33 }; //string sigleJSON = JavaScriptConvert.SerializeObject(s); //StuInfo newS = (StuInfo)JavaScriptConvert.DeserializeObject(sigleJSON);
//Console.WriteLine("姓名:" + newS.StuName + "---性别:" + newS.StuSex + "--年龄:" + newS.StuAge + "\n\n"); foreach (StuInfo item in newList)
{
Console.WriteLine("姓名:" + item.StuName + "---性别:" + item.StuSex + "--年龄:" + item.StuAge + "\n\n");
}
Console.ReadLine();
}
}
public class StuInfo
{
public string StuName { set; get; }
public string StuSex { set; get; }
public int StuAge { set; get; }
}
}

  2.在web中

/// <summary>
/// Handler1 的摘要说明
/// </summary>
public class Handler1 : IHttpHandler
{ public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "application/json"; List<StuInfo> list = new List<StuInfo>() { new StuInfo{StuName="张三",StuSex="男",StuAge=11},
new StuInfo{StuName="李四",StuSex="男",StuAge=32},
new StuInfo{StuName="王翠花",StuSex="女",StuAge=64}
};
string jsonStr = JavaScriptConvert.SerializeObject(list); context.Response.Write(jsonStr); context.Response.End();
} public bool IsReusable
{
get
{
return false;
}
}
}
public class StuInfo
{
public string StuName { set; get; }
public string StuSex { set; get; }
public int StuAge { set; get; }
}

  前台页面上的调用:这里采用jquery 的ajax请求

<head runat="server">
<title>JSON</title>
<script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(function () {
$("#btnOK").click(function () {
$.ajax({
type: "JSON",
url: "Handler1.ashx",
data: null,
success: function (msg) {
var con="";
for (var i = 0; i < msg.length; i++) {
con += "姓名:" + msg[i].StuName + "--性别:" + msg[i].StuSex + "--" + "--年龄:" + msg[i].StuAge+"<br/>";
} $("#divContent").html("长度:" + msg.length + "--具体内容:<br/>" + con);
}
});
});
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<input type="button" id="btnOK" value="点我获得JSON数据" />
<div id="divContent"></div>
</div>
</form>
</body>

现在经常会用到json,因此经常会需要对其进行序列化和反序列化。,.NET Framewok 3.5也提供了JSON对象序列化和反序列化的类,这就是System.Runtime.Serialization.Json 命名空间下的 DataContractJsonSerializer 类。利用这个类,可以实现JSON对象的序列化和反序列化。

现在我提供一个类JSON对象序列化和反序列化的类供参考用:

/// <summary>
/// JSON帮助类。用于将对象转换为Json格式的字符串,或者将Json的字符串转化为对象。
/// </summary>
public static class JsonHelper
{
/// <summary>
/// 将对象转化为Json字符串
/// </summary>
/// <typeparam name="T">源类型</typeparam>
/// <param name="obj">源类型实例</param>
/// <returns>Json字符串</returns>
public static string GetJsonFromObj<T>(T obj)
{
DataContractJsonSerializer jsonSerializer = new DataContractJsonSerializer(obj.GetType());
using (MemoryStream ms = new MemoryStream())
{
jsonSerializer.WriteObject(ms, obj);
return Encoding.UTF8.GetString(ms.ToArray());
}
} /// <summary>
/// 将Json字符串转化为对象
/// </summary>
/// <typeparam name="T">目标类型</typeparam>
/// <param name="strJson">Json字符串</param>
/// <returns>目标类型的一个实例</returns>
public static T GetObjFromJson<T>(string strJson)
{
T obj = Activator.CreateInstance<T>();
using (MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(strJson)))
{
DataContractJsonSerializer jsonSerializer = new DataContractJsonSerializer(obj.GetType());
return (T)jsonSerializer.ReadObject(ms);
}
} /// <summary>
/// 将DataTable转换为JSON字符串
/// </summary>
/// <param name="dt">数据表</param>
/// <returns>JSON字符串</returns>
public static string GetJsonFromDataTable(DataTable dt)
{
StringBuilder JsonString = new StringBuilder();
if (dt != null && dt.Rows.Count > 0)
{
JsonString.Append("{ ");
JsonString.Append("\"TableInfo\":[ ");
for (int i = 0; i < dt.Rows.Count; i++)
{
JsonString.Append("{ ");
for (int j = 0; j < dt.Columns.Count; j++)
{
if (j < dt.Columns.Count - 1)
{
JsonString.Append("\"" + dt.Columns[j].ColumnName.ToString() + "\":" + "\"" + dt.Rows[i][j].ToString() + "\",");
}
else if (j == dt.Columns.Count - 1)
{
JsonString.Append("\"" + dt.Columns[j].ColumnName.ToString() + "\":" + "\"" + dt.Rows[i][j].ToString() + "\"");
}
}
if (i == dt.Rows.Count - 1)
{
JsonString.Append("} ");
}
else
{
JsonString.Append("}, ");
}
}
JsonString.Append("]}");
return JsonString.ToString();
}
else
{
return null;
}
} /// <summary>
/// 将对象转化为Json字符串
/// </summary>
/// <param name="obj">源对象</param>
/// <returns>json数据</returns>
public static string ObjToJson(this object obj)
{
JavaScriptSerializer serialize = new JavaScriptSerializer();
return serialize.Serialize(obj);
} /// <summary>
/// 将Json字符串转化为对象
/// </summary>
/// <param name="strJson">Json字符串</param>
/// <returns>目标对象</returns>
public static T JsonToObj<T>(string strJson)
{
JavaScriptSerializer serialize = new JavaScriptSerializer();
return serialize.Deserialize<T>(strJson);
} /// <summary>
/// 将对象转化为Json字符串(控制深度 )
/// </summary>
/// <param name="obj">源对象</param>
/// <param name="recursionDepth">深度</param>
/// <returns>json数据</returns>
public static string ObjToJson(this object obj, int recursionDepth)
{
JavaScriptSerializer serialize = new JavaScriptSerializer();
serialize.RecursionLimit = recursionDepth;
return serialize.Serialize(obj);
} /// <summary>
/// 将Json字符串转化为对象(控制深度 )
/// </summary>
/// <param name="strJson">Json字符串</param>
/// <param name="recursionDepth">深度</param>
/// <returns>目标对象</returns>
public static T JsonToObj<T>(string strJson, int recursionDepth)
{
JavaScriptSerializer serialize = new JavaScriptSerializer();
serialize.RecursionLimit = recursionDepth;
return serialize.Deserialize<T>(strJson);
} /// <summary>
/// 将DataTable转换为JSON字符串
/// </summary>
/// <param name="dt">DataTable</param>
/// <returns>json数据</returns>
public static string DataTableToJson(DataTable dt)
{
Dictionary<string, object> dic = new Dictionary<string, object>(); int index = 0;
foreach (DataRow dr in dt.Rows)
{
Dictionary<string, object> result = new Dictionary<string, object>(); foreach (DataColumn dc in dt.Columns)
{
result.Add(dc.ColumnName, dr[dc].ToString());
}
dic.Add(index.ToString(), result);
index++;
}
return ObjToJson(dic);
}
}

  使用如下:

public partial class WebForm1 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{ } protected void Button1_Click(object sender, EventArgs e)
{
//反序列化成对象
String strJson = "{\"Name\":\"Test123\",\"Url\":\"http://www.126.com/\"}";
Person p1 = JsonHelper.GetObjFromJson<Person>(strJson);
Response.Write("<li>" + p1.Name + " " + p1.Url);
Person p2 = JsonHelper.JsonToObj<Person>(strJson);
Response.Write("<li>" + p2.Name + " " + p2.Url);
} protected void Button2_Click(object sender, EventArgs e)
{
//对象的序列化
String JSONString = string.Empty;
Person p1 = new Person();
p1.Name = "Test123'\"\n\r\t";
p1.Url = "http://www.126.com/";
JSONString = JsonHelper.GetJsonFromObj<Person>(p1);
Response.Write("<li>" + JSONString);
JSONString = JsonHelper.ObjToJson(p1);
Response.Write("<li>" + JSONString);
}
} /// <summary>
/// 类对象需要标记为DataContractAttribute
/// </summary>
[DataContractAttribute]
class Person
{
//成员需要标记为 DataMember
[DataMember]
public string Name { set; get; }
[DataMember]
public string Url { set; get; }
}

补充:

在C#中可以对JSON进行序列化与反序列化,十分的方便。代码如下:

首先引入命名空间:using System.Web.Script.Serialization;

再定义一个类,如下:

public class jsonClass
{
public string id;
public string name;
public string pId;
public string isParent;
public string open;
public string senable;
public string CHECKED;
public string chkDisabled; }

将一个JSON字符串转换成jsonClass类实例,如下:

JavaScriptSerializer serializer = new JavaScriptSerializer();
List<jsonClass> jsonClassList = serializer.Deserialize<List<jsonClass>>(jsonString);

将List<jsonClass>转换成json

string resultString = serializer.Serialize(jsonClassList);

转自:http://blog.csdn.net/hellojimmy520/article/details/7377265

.NET下 JSON 的一些常用操作的更多相关文章

  1. ubuntu下安装mysql及常用操作

    1.可通过ps -ef | grep mysql命令查看系统中是否有安装mysql 如果出现类似上述的页面,就证明是已经安装过了mysql,否则就是没有. 2.安装mysql 很简单,只需要键入如下命 ...

  2. 网站用户行为分析——在Ubuntu下安装MySQL及其常用操作

    安装MySQL 使用以下命令即可进行mysql安装,注意安装前先更新一下软件源以获得最新版本: sudo apt-get update #更新软件源 sudo apt-get install mysq ...

  3. ubuntu下安装redis及常用操作

    reids是一个内存数据库,具有存取速度快,使用简单等优点.我们常常在分布式或者负载均衡的系统中使用它来缓存一些公用的且不是很大量的数据,比如session或者各类token(比如微信的access_ ...

  4. Js 中对 Json 数组的常用操作

    我们首先定义一个json数组对象如下: var persons = [ {name: "tina", age: 14}, {name: "timo", age: ...

  5. mysql8.0 新特性,对json类型的常用操作

    mysql8 新特性-json数据类型操作 -- 根据key(可多个)获取value SELECT JSON_EXTRACT('{"id": 14, "name" ...

  6. Linux下进程和端口常用操作

    https://blog.csdn.net/s573626822/article/details/80680456

  7. mongodb的常用操作

    对于nosql之前工作中有用到bekerlydb,最近开始了解mongodb,先简单写下mongodb的一些常用操作,当是个总结: 1.mongodb使用数据库(database)和集合(collec ...

  8. jquery下json数组的操作用法实例

    jquery下json数组的操作用法实例: jquery中操作JSON数组的情况中遍历方法用的比较多,但用添加移除这些好像就不是太多了. 试过json[i].remove(),json.remove( ...

  9. linux下关于gz和bz2压缩格式的常用操作技巧

    .gz和.bz2都是linux下压缩文件的格式,有点类似windows下的.zip和.rar文件..bz2和.gz的区别在于,前者比后者压缩率更高,后者比前者花费更少的时间. 也就是说同一个文件,压缩 ...

随机推荐

  1. React.js 的 context

    这一节我们来介绍一个你可能永远用不上的 React.js 特性 —— context.但是了解它对于了解接下来要讲解的 React-redux 很有好处,所以大家可以简单了解一下它的概念和作用. 在过 ...

  2. 用户控件引用Entity Framework

    背景: 今天在做软件的时候,出现了问题,我在项目里面添加了Entity Framework,在form的代码里引用没有问题,在userControl里引用就出了问题. 我检查app.config文件 ...

  3. SpringBoot 2.x (5):异常处理与部署WAR项目

    异常处理: SpringBoot的异常处理是不友好的,前端只会显示最基本的错误名称 后端控制台会报出具体的错误,那么我们如何告知前端具体的错误信息呢? 1:对全局异常进行处理 一个测试的Control ...

  4. html制作简单框架网页二 实现自己的影音驿站 操作步骤及源文件下载 (可播放mp4、avi、mpg、asx、swf各种文件的视频播放代码)

    新增视频播放功能如下图: 左侧网页left.html代码如下: <meta charset="utf-8"> <body style="backgrou ...

  5. ES6学习笔记(10)----Set和Map数据结构

    参考书<ECMAScript 6入门>http://es6.ruanyifeng.com/ Set和Map数据结构 1.Set  基本用法    Set是一种新的数据结构,它的成员都是唯一 ...

  6. ElasticSearch可视化工具 Kibana

    Kibana要和ElasticSearch 版本一致,默认的端口号是:5601

  7. Django 你需要了解的入门操作

    创建一个django project   (我的版本是1.11.11) django-admin startproject mysite cd mysite 当前目录下会生成mysite的工程,目录结 ...

  8. 搜索 || DFS || POJ 2488 A Knight's Journey

    给一个矩形棋盘,每次走日字,问能否不重复的走完棋盘的每个点,并将路径按字典序输出 *解法:按字典序输出路径,因此方向向量的数组按字典序写顺序,dfs+回溯,注意flag退出递归的判断,并且用pre记录 ...

  9. Chrome浏览器商店安装的插件保存到本地

    Chrome自67版本开始,不能从第三方下载插件拖动安装,要么就是以前的方法安装修改为zip格式,会有报错(报错如下图),强迫症肯定忍不了报错的:按照网上说法,是第三方插件的压缩算法和Chrome商店 ...

  10. SqlSugar直接执行Sql

    参考:http://www.codeisbug.com/Doc/8/1132 我的思路: 1.数据库中写好sql 2.用SqlSugar直接执行sql,获取DataTable的数据 3.DataTab ...