最近在作一個使用基於.net mvc 實現先後臺傳輸Json的實例。網上找了一些資料。發如今開發的時候,許多的數據交互都是以Json格式傳輸的。其中涉及序列化對象的使用的有DataContractJsonSerializer,JavaScriptSerializer和Json.net即Newtonsoft.Json.其中Json.net並非微軟的類庫。是一個開源的世界級的Json操做類庫。相對熟悉的只有JavaScriptSerializer這個序列化對象。可是,看了資料發現使用Json.net序列化對象比使用JavaScriptSerializer序列化對象性能上簡直是一個天上一個地下。html
如下是網上找到的它們之間的性能的對比圖:
json
如何安裝Json.netmvc
由於Json.net不是微軟的類庫。因此,有兩種方式使用:ide
方法1:可去官網下載壓縮版。傳送地址:https://www.newtonsoft.com。工具
方法2:可在vs中開發工具中 選擇菜單中工具->Nuget程序包管理器->程序包管理器程序臺->輸入 Install-Package Newtonsoft.Json -Version 11.0.2 安裝便可。性能
或者能夠在選擇菜單中工具->Nuget程序包管理器->管理解決方案的NuGet程序包->聯機->查詢到Json.net點擊安裝。開發工具
注意:若是安裝出現錯誤信息爲:「Newtonsoft.Json」已擁有爲「Microsoft.CSharp」定義的依賴項。說明NuGet的版本過低。spa
第一步:請卸載低版本的NuGet。卸載步驟:打開VS->打開菜單「工具」-「擴展管理器」->選擇「NuGet Package Manager」->點擊「卸載」。.net
第二步:重啓VS。code
第三步:在「聯機」選項中搜索「NuGet」,找到 NuGet Package Manager 點擊下載,完成自動安裝。
如何使用Json.net
在須要使用的控制器中引用命名空間using.Newtonsoft.Json;
json.net基礎用法是直接序列化和反序列化DataTable,DataSet,Entity Framework和Entity。
序列化:
//序列化DataTable DataTable dt = new DataTable(); dt.Columns.Add("Age", Type.GetType("System.Int32")); dt.Columns.Add("Name", Type.GetType("System.String")); dt.Columns.Add("Sex", Type.GetType("System.String")); dt.Columns.Add("IsMarry", Type.GetType("System.Boolean")); for (int i = 0; i < 4; i++) { DataRow dr = dt.NewRow(); dr["Age"] = i + 1; dr["Name"] = "Name" + i; dr["Sex"] = i % 2 == 0 ? "男" : "女"; dr["IsMarry"] = i % 2 > 0 ? true : false; dt.Rows.Add(dr); } Console.WriteLine(JsonConvert.SerializeObject(dt));
反序列化:
string json = JsonConvert.SerializeObject(dt); dt=JsonConvert.DeserializeObject<DataTable>(json); foreach (DataRow dr in dt.Rows) { Console.WriteLine("{0}\t{1}\t{2}\t{3}\t", dr[0], dr[1], dr[2], dr[3]); }
Json.net的高級用法
1.忽略某些屬性(OpIn的用法)
[JsonObject(MemberSerialization.OptIn)] //OptIn默認狀況下,全部的成員不會被序列化,類中的成員只有標有特性JsonProperty的纔會被序列化。 public partial class SysUser { public int ID { get; set; } public string UserName { get; set; } public string Email { get; set; } [JsonProperty] public string PassWord { get; set; } public DateTime dAddTime { get; set; } public virtual ICollection<SysUserRole> SysUserRole { get; set; } }
只用密碼顯示,其餘不顯示。
效果如圖:
忽略某些屬性(OpOut的用法)
[JsonObject(MemberSerialization.OptOut)] //OptIn默認狀況下,全部的成員不會被序列化,類中的成員只有標有特性JsonProperty的纔會被序列化。 public partial class SysUser { public int ID { get; set; } public string UserName { get; set; } public string Email { get; set; } [JsonIgnore] public string PassWord { get; set; } public DateTime dAddTime { get; set; } public virtual ICollection<SysUserRole> SysUserRole { get; set; } }
最後密碼就被隱藏,其餘都顯示。
效果如圖:
2.日期處理
使用Json.net處理的日期系統會自帶iso日期標準,可是在實際的開發中大多數使用的多是yyyy-MM-dd 或者yyyy-MM-dd HH:mm:ss兩種格式的日期。因此,有兩種解決方案:
方案1: Json.Net提供了IsoDateTimeConverter日期轉換這個類,能夠經過JsnConverter實現相應的日期轉換
public class SysUser { public int ID { get; set; } public string UserName { get; set; } public string Email { get; set; } public string PassWord { get; set; } [JsonConverter(typeof(IsoDateTimeConverter))] public DateTime dAddTime { get; set; } }
方案2:如若IsoDateTimeConverter日期格式不是咱們想要的能夠繼承該類實現本身的日期
public class ChinaDateTimeConverter : DateTimeConverterBase { private static IsoDateTimeConverter dtConverter = new IsoDateTimeConverter { DateTimeFormat = "yyyy-MM-dd" }; public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) { return dtConverter.ReadJson(reader, objectType, existingValue, serializer); } public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) { dtConverter.WriteJson(writer, value, serializer); } }
而後在Model中使用
public class SysUser { public int ID { get; set; } public string UserName { get; set; } public string Email { get; set; } public string PassWord { get; set; } [JsonConverter(typeof(ChinaDateTimeConverter))] public DateTime dAddTime { get; set; } }
效果如圖:
文章摘自:https://www.cnblogs.com/mq0036/p/7017999.html