開始用的.net 內建的DataContractJsonSerializer進行序列化和還原序列化,當代碼寫完以後,調試,我X(原諒我的髒話,因為確實讓我生氣),實體因為有[DataContractAttribute(IsReference=true )] 這樣一個屬性,提示不能序列化,當然手改一下啦,改完以後,提示基類EntityObject 的這個屬性不可以
MY God!!
後來也是因為DataContractJsonSerializer 還原序列化成集合的時候不好使,所以才下定決心廢棄。採用了第三方的東西:傳說中的Json.net
今天我也是要說這個組件序列化和還原序列化的功能:
廢話少說,線上model ,作為提供資料的使用
複製代碼 代碼如下:public class wf_Task_Inbox
{
public wf_Task_Inbox(string id,string name)
{
this.ID = id;
this.Name = name;
}
[DataMember ]
public string ID { get; set; }
[DataMember]
public string Name{get ;set ;}
}
這裡主要是作為測試時的資料來源
接下來是序列化的代碼,為了對比清楚,先奉上.net 內建的方法: 複製代碼 代碼如下:/// <summary>
/// 把一個對象轉化為json格式資料
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
public string EntityToJson(wf_Task_Inbox entity)
{
DataContractJsonSerializer serializer = newDataContractJsonSerializer(entity.GetType());
using (MemoryStream stream = new MemoryStream())
{
serializer.WriteObject(stream, entity);
return Encoding.UTF8.GetString(stream .ToArray ());
}
}
返回的是個字串,集合序列化的方法類似;
下邊是json.net的代碼:
JsonConvert .SerializeObject (list, Formatting.None ); 有且只有一行!!!!當然首先得添加json.net的引用
接下是還原序列化的代碼,.net 內建: 複製代碼 代碼如下:/// <summary>
/// 將json 資料轉化為對象
/// </summary>
/// <param name="entity"></param>
/// <param name="jsonstring"></param>
/// <returns></returns>
public wf_Task_Inbox JsonToEntity(string jsonstring)
{
DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(wf_Task_Inbox));
using (MemoryStream mStream = new MemoryStream(Encoding.UTF8.GetBytes(jsonstring)))
{
return serializer.ReadObject(mStream) as wf_Task_Inbox;
}
}
同時也是因為內建的木有泛型的擴充,所以不太喜歡,json.net的方法:
JsonConvert.DeserializeObject<List<wf_Task_Inbox>>(jsonstring) ; 這個是集合的,當然單個對象的怎麼弄,你懂的,去掉《T》 就行了唄....
產生的序列化資料是標準的json格式:
[{"ID":"0","Name":"姓名:0"},{"ID":"1","Name":"姓名:1"},{"ID":"2","Name":"姓名:2"},{"ID":"3","Name":"姓名:3"},{"ID":"4","Name":"姓名:4"},{"ID":"5","Name":"姓名:5"},{"ID":"6","Name":"姓名:6"},{"ID":"7","Name":"姓名:7"},{"ID":"8","Name":"姓名:8"},{"ID":"9","Name":"姓名:9"}]
最後附上json.net的,下載包裡有協助和各個版本的json.net
http://json.codeplex.com/Release/ProjectReleases.aspx