.NET下 JSON 的一些常用操作
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 的一些常用操作的更多相关文章
- ubuntu下安装mysql及常用操作
1.可通过ps -ef | grep mysql命令查看系统中是否有安装mysql 如果出现类似上述的页面,就证明是已经安装过了mysql,否则就是没有. 2.安装mysql 很简单,只需要键入如下命 ...
- 网站用户行为分析——在Ubuntu下安装MySQL及其常用操作
安装MySQL 使用以下命令即可进行mysql安装,注意安装前先更新一下软件源以获得最新版本: sudo apt-get update #更新软件源 sudo apt-get install mysq ...
- ubuntu下安装redis及常用操作
reids是一个内存数据库,具有存取速度快,使用简单等优点.我们常常在分布式或者负载均衡的系统中使用它来缓存一些公用的且不是很大量的数据,比如session或者各类token(比如微信的access_ ...
- Js 中对 Json 数组的常用操作
我们首先定义一个json数组对象如下: var persons = [ {name: "tina", age: 14}, {name: "timo", age: ...
- mysql8.0 新特性,对json类型的常用操作
mysql8 新特性-json数据类型操作 -- 根据key(可多个)获取value SELECT JSON_EXTRACT('{"id": 14, "name" ...
- Linux下进程和端口常用操作
https://blog.csdn.net/s573626822/article/details/80680456
- mongodb的常用操作
对于nosql之前工作中有用到bekerlydb,最近开始了解mongodb,先简单写下mongodb的一些常用操作,当是个总结: 1.mongodb使用数据库(database)和集合(collec ...
- jquery下json数组的操作用法实例
jquery下json数组的操作用法实例: jquery中操作JSON数组的情况中遍历方法用的比较多,但用添加移除这些好像就不是太多了. 试过json[i].remove(),json.remove( ...
- linux下关于gz和bz2压缩格式的常用操作技巧
.gz和.bz2都是linux下压缩文件的格式,有点类似windows下的.zip和.rar文件..bz2和.gz的区别在于,前者比后者压缩率更高,后者比前者花费更少的时间. 也就是说同一个文件,压缩 ...
随机推荐
- forward和sendRedirect的区别
部分内容转自:http://blog.csdn.net/zhouysh/article/details/380364和http://blog.csdn.net/frank_jay/article/de ...
- 猩球StarBall ,一个方便约球的小程序
扫描小程序码直接进入小程序 猩球StarBall 是一款为热爱运动的人群提供便利的小程序. 开发技术为Java +Mysql 其中用到的技术框架为SpringBoot,Mybatis,Redis,Qu ...
- a=a+b与a+=b的区别
在一次工作中身边的一位资深的同事突然问了个a=a+b与a+=b有什么区别 此时有点尴尬了 不知道是真的不知道咧还是别有用意....今天抽点时间针对此问题做个小总结 一.性能方面 a=a+b是加法运算 ...
- TigerGraph REST++API
简介 - 什么是REST ++? TigerGraph TM 系统使用着名的REpresentational State Transfer(REST)架构来管理与TigerGraph核心组件,图形处理 ...
- 谈谈对Android中的消息机制的理解
Android中的消息机制主要由Handler.MessageQueue.Looper三个类组成,他们的主要作用是 Handler负责发送.处理Message MessageQueue负责维护Mess ...
- C# 移动控件
最近要做车牌识别的,不同地区收费标准不一,所以想做个可以移动控件来给客户选择停车场收费条件的. 首先因为要自动排序控件选FlowLayoutPanel做容器,加若干Panel和FlowLayout ...
- vue下axios和fetch跨域请求
1.在config的index.js下面进行常用跨域配置代码:proxyTable: { '/apis': { //使用"/api"来代替"http://xxxx.cn& ...
- gulp自动化构建工具使用
gulpfile.js: var gulp = require("gulp"); var imagemin = require("gulp-imagemin") ...
- Linux之用户权限管理
chmod(更改目录或文件权限) 在linux中,文件的权限分为3中,拥有者,群组,其他人.而chmod则是对权限更改的命令. u 表示该文件的拥有者,g 表示与该文件的拥有者属于同一个组,o 表示其 ...
- Mysql 访问远程数据库,报错:1130-host ... is not allowed to connect to this MySql server 开放mysql远程连接 不使用localhost
参考:http://www.cnblogs.com/xyzdw/archive/2011/08/11/2135227.html 解决方法: 1. 改表法. 可能是你的帐号不允许从远程登陆,只能在loc ...