.NET下 JSON 的一些常用操作

时间:2022-09-16 15:05:03

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

首先要先添加引用:.NET下 JSON 的一些常用操作

代码如下

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中

首先添加一个一般处理文件 Handler1.ashx:用来返回一个json

/// <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; }
    }

Json.NET json字符串反序列化为json对象 


如何将一个字符串转换为JSON对象呢?如果先创建一个类的话,那就太累了。

var o = new
{
   a = 1,
   b = "Hello, World!",
   c = new[] { 1, 2, 3 },
   d = new Dictionary<string, int> { { "x", 1 }, { "y", 2 } }
};

var json = JsonConvert.SerializeObject(o);

现在json是一个字符串。

第一种做法(匿名类):

var anonymous = new { a = 0, b = String.Empty, c = new int[0], d = new Dictionary<string, int>() };
var o2 = JsonConvert.DeserializeAnonymousType(json, anonymous);

Console.WriteLine(o2.b);
Console.WriteLine(o2.c[1]);

第二种做法(匿名类):

var o3 = JsonConvert.DeserializeAnonymousType(json, new { c = new int[0], d = new Dictionary<string, int>() });

Console.WriteLine(o3.d["y"]);

DeserializeAnonymousType 只是借助这个匿名对象参数(anonymous) 反射类型而已,也就是说它和反序列化结果并非同一个对象。正如 o3 那样,我们也可以只提取局部信息。

 

第三种做法(索引器):

实际上,我们也可以直接反序列化为 JObject,然后通过索引器直接访问。JObject、JProperty 等都继承自 JToken,它重载了基元类型转换操作符,我们可以直接得到实际结果。
var o2 = JsonConvert.DeserializeObject(json) as JObject;

Console.WriteLine((int)o2["a"]);
Console.WriteLine((string)o2["b"]);
Console.WriteLine(o2["c"].Values().Count());
Console.WriteLine((int)o2["d"]["y"]);