C#中JSON的理解

轉自:http://blog.csdn.net/coolszy/article/details/8606803 html


JSON簡介json

JSON(全稱爲JavaScript ObjectNotation) 是一種輕量級的數據交換格式。它是基於JavaScript語法標準的一個子集。JSON採用徹底獨立於語言的文本格式,能夠很容易在各類網絡、平臺和程序之間傳輸。JSON的語法很簡單,易於人閱讀和編寫,同時也易於機器解析和生成。數組

 

JSONXML的比較網絡

◆可讀性ide

JSON和XML的可讀性相比較而言,因爲XML提供輔助的標籤,更加適合人閱讀和理解。工具

◆文件大小與傳輸ui

XML容許使用方便的標籤,因此文件尺寸是要比JSON大的。並且JSON源於Javascript,因此天生的主戰場是Javascript與網絡,在這裏,JSON有着XML沒法趕超的優點。url

 

JSON語法spa

1. JSON 語法是 JavaScript 對象表示法語法的子集。.net

數據在名稱/值對中:名稱是字符串,使用雙引號表示。值能夠是:數字(整數或浮點數),字符串(在雙引號中),數組(在方括號中),對象(在花括號中),true/false/null。

數據由逗號分隔:

花括號保存對象:對象能夠包含各類數據,包括數組。

方括號保存數組:數字能夠包含對象。

例如:


[html] view plaincopy

  1. {  

  2.    "students": [  

  3.        {  

  4.            "name": "coolszy",  

  5.            "age": 24  

  6.        },  

  7.        {  

  8.            "name": "kuka",  

  9.            "age": 24  

  10.        }  

  11.     ]  

  12. }  

2. 若是JSON中含有轉義字符,則須要轉義。


 

C#操做JSON

JSON文件讀入到內存中就是字符串,.NET操做JSON就是生成與解析JSON字符串。操做JSON一般有如下幾種方式:

1. 原始方式

本身按照JSON的語法格式,寫代碼直接操做JSON字符串。如非必要,應該不多人會走這條路,從頭再來的。

 

2. 通用方式

這種方式是使用開源的類庫Newtonsoft.Json(下載地址http://json.codeplex.com/)。下載後加入工程就能用。一般可使用JObject, JsonReader, JsonWriter處理。這種方式最通用,也最靈活,能夠隨時修改不爽的地方。

(1)使用JsonReader讀Json字符串:


[csharp] view plaincopy

  1. string jsonText =@"{""input"" : ""value"",""output"" : ""result""}";  

  2. JsonReader reader = new JsonTextReader(newStringReader(jsonText));  

  3. while (reader.Read())  

  4. {  

  5.    Console.WriteLine(reader.TokenType + "\t\t" + reader.ValueType+ "\t\t" + reader.Value);  

  6. }  


(2)使用JsonWriter寫字符串:




[csharp] view plaincopy

  1. StringWriter sw = new StringWriter();  

  2. JsonWriter writer = new JsonTextWriter(sw);  

  3.    

  4. writer.WriteStartObject();  

  5. writer.WritePropertyName("input");  

  6. writer.WriteValue("value");  

  7. writer.WritePropertyName("output");  

  8. writer.WriteValue("result");  

  9. writer.WriteEndObject();  

  10. writer.Flush();  

  11.    

  12. string jsonText =sw.GetStringBuilder().ToString();  

  13. Console.WriteLine(jsonText);  


(3)使用JObject讀寫字符串:



[csharp] view plaincopy

  1. JObject jo = JObject.Parse(jsonText);  

  2. string[] values =jo.Properties().Select(item => item.Value.ToString()).ToArray();  


(4)使用JsonSerializer讀寫對象(基於JsonWriter與JsonReader):


數組型數據


[csharp] view plaincopy

  1. string jsonArrayText1 ="[{'a':'a1','b':'b1'},{'a':'a2','b':'b2'}]";  

  2. JArray ja =(JArray)JsonConvert.DeserializeObject(jsonArrayText1);  

  3. string ja1a =ja[1]["a"].ToString();  

  4. //或者  

  5. JObject o = (JObject)ja[1];  

  6. string oa = o["a"].ToString();  


嵌套格式


 

[csharp] view plaincopy

  1. string jsonText ="{\"beijing\":{\"zone\":\"海淀\",\"zone_en\":\"haidian\"}}";  

  2. JObject jo =(JObject)JsonConvert.DeserializeObject(jsonText);  

  3. string zone =jo["beijing"]["zone"].ToString();  

  4. string zone_en =jo["beijing"]["zone_en"].ToString();  



自定義類Project


[csharp] view plaincopy

  1. Project p = new Project() { Input ="stone", Output = "gold" };  

  2. JsonSerializer serializer = newJsonSerializer();  

  3. StringWriter sw = new StringWriter();  

  4. serializer.Serialize(newJsonTextWriter(sw), p);  

  5. Console.WriteLine(sw.GetStringBuilder().ToString());  

  6.    

  7. StringReader sr = newStringReader(@"{""Input"":""stone"",""Output"":""gold""}");  

  8. Project p1 =(Project)serializer.Deserialize(new JsonTextReader(sr), typeof(Project));  

  9. Console.WriteLine(p1.Input +"=>" + p1.Output);  


上面的代碼都是基於下面這個Project類定義:


 

[csharp] view plaincopy

  1. class Project  

  2. {  

  3.    public string Input { getset; }  

  4.    public string Output { getset; }  

  5. }  


此外,若是上面的JsonTextReader等類編譯不過的話,說明是咱們本身修改過的類,換成大家本身的相關類就能夠了,不影響使用。

 

3. 內置方式

使用.NET Framework 3.5/4.0中提供的System.Web.Script.Serialization命名空間下的JavaScriptSerializer類進行對象的序列化與反序列化,很直接。

 

[csharp] view plaincopy

  1. Project p = new Project() { Input ="stone", Output = "gold" };  

  2. JavaScriptSerializer serializer = newJavaScriptSerializer();  

  3. varjson = serializer.Serialize(p);  

  4. Console.WriteLine(json);  

  5.   

  6. varp1 = serializer.Deserialize<Project>(json);  

  7. Console.WriteLine(p1.Input+ "=>" + p1.Output);  

  8. Console.WriteLine(ReferenceEquals(p,p1));  


注意:若是使用的是VS2010,則要求當前的工程的Target Framework要改爲.Net Framework 4,不能使用Client Profile。固然這個System.Web.Extensions.dll主要是Web使用的,直接在Console工程中用感受有點浪費資源。


此外,從最後一句也能夠看到,序列化與反序列化是深拷貝的一種典型的實現方式。

 

4. 契約方式

使用System.Runtime.Serialization.dll提供的DataContractJsonSerializer或者JsonReaderWriterFactory實現。

 

[csharp] view plaincopy

  1. Project p = new Project() { Input ="stone", Output = "gold" };  

  2. DataContractJsonSerializer serializer = newDataContractJsonSerializer(p.GetType());  

  3. string jsonText;  

  4.    

  5. using (MemoryStream stream = newMemoryStream())  

  6. {  

  7.    serializer.WriteObject(stream, p);  

  8.    jsonText = Encoding.UTF8.GetString(stream.ToArray());  

  9.     Console.WriteLine(jsonText);  

  10. }  

  11.    

  12. using (MemoryStream ms = newMemoryStream(Encoding.UTF8.GetBytes(jsonText)))  

  13. {  

  14.    DataContractJsonSerializer serializer1 = newDataContractJsonSerializer(typeof(Project));  

  15.    Project p1 = (Project)serializer1.ReadObject(ms);  

  16.    Console.WriteLine(p1.Input + "=>" + p1.Output);  

  17. }  



這裏要注意,這裏的Project類和成員要加相關的Attribute:

 

[csharp] view plaincopy

  1. [DataContract]  

  2. class Project  

  3. {  

  4.    [DataMember]  

  5.    public string Input { getset; }  

  6.    [DataMember]  

  7.    public string Output { getset; }  

  8. }  

  9.    



實用參考:

JSON驗證工具:http://jsonlint.com/

JSON簡明教程:http://www.w3school.com.cn/json/

Newtonsoft.Json類庫下載:http://json.codeplex.com/

相關文章
相關標籤/搜索