您好,登錄后才能下訂單哦!
這篇文章主要介紹“如何使用 ServiceStack.Text 序列化 json”,在日常操作中,相信很多人在如何使用 ServiceStack.Text 序列化 json問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何使用 ServiceStack.Text 序列化 json”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
相信做 .net 開發(fā)的朋友經(jīng)常會遇到 json 序列化這樣的需要,今天發(fā)篇文章總結(jié)下自己使用ServiceStack.Text 來序列化 json。它的速度比 Newtonsoft.Json 快很多,在測試時(shí)發(fā)現(xiàn)比 fastJson 還快些。
首先,我們有下邊兩個(gè)類,一個(gè)是職員(Staff)類,一個(gè)是聯(lián)系方式(Contact)類:
復(fù)制代碼 代碼如下:
public class Staff
{
public long ID { get; set; }
public string Name { get; set; }
public int Age { get; set; }
}
public class Contact
{
public long StaffID { get; set; }
public string Email { get; set; }
}
首先,我們添加兩個(gè)職員:
復(fù)制代碼 代碼如下:
List<Staff> listStaff = new List<Staff>();
listStaff.Add(new Staff() { ID = 2, Name = "小李" });
listStaff.Add(new Staff() { ID = 3, Name = "小王" });
按以前很多人序列化 json 的方式:
復(fù)制代碼 代碼如下:
var result = "[";
foreach (var staff in listStaff)
{
result += "{\"ID\":\"" + staff.ID + "\",\"Name\":\"" + staff.Name + "\"},";
}
result = result.Substring(0, result.Length - 1);
result += "]";
最終 json 如下:
復(fù)制代碼 代碼如下:
[
{
"ID": "2",
"Name": "小李"
},
{
"ID": "3",
"Name": "小王"
}
]
使用這種方式是可以的,但有幾個(gè)缺點(diǎn):1.代碼顯得雜亂,易出錯(cuò)。2.需要自己對特殊字符進(jìn)行轉(zhuǎn)義,如雙引號等,否則 json 序列化將失敗。下邊看看使用 ServiceStack.Text 來序列化 json。
我們需要下載 ServiceStack.Text.dll,將它引用到我們的項(xiàng)目中,并引用 ServiceStack.Text 命名空間。下邊先看看單個(gè)類對象的序列化:
復(fù)制代碼 代碼如下:
Staff staff = new Staff() { ID = 1, Name = "xiaozhao" };
var result = staff.ToJson();
這樣得到的 json 如下:
復(fù)制代碼 代碼如下:
{
"ID": 1,
"Name": "xiaozhao",
"Age": 0
}
細(xì)心的朋友會發(fā)現(xiàn),我們在輸出中并不打算使用 Age 屬性,但這里卻輸出了 Age,為解決這個(gè)問題,我們有下邊方法。
1.使用 JsonObject 類,它繼承自Dictionary<string, string>,使得我們可以如下來輸出我們想要的屬性。
復(fù)制代碼 代碼如下:
Staff staff = new Staff() { ID = 1, Name = "xiaozhao" };
JsonObject json = new JsonObject();
json.Add("ID", staff.ID.ToString());
json.Add("Name", staff.Name);
var result = json.ToJson();
這樣得到下邊的結(jié)果[結(jié)果一],達(dá)到了我們的目的。
復(fù)制代碼 代碼如下:
{
"ID": 1,
"Name": "xiaozhao"
}
2.在項(xiàng)目中添加 System.Runtime.Serialization ,并引用命名空間 System.Runtime.Serialization。
我們可以在屬性上邊指明要序列化的屬性,如下:
復(fù)制代碼 代碼如下:
[DataContract]
public class Staff
{
[DataMember]
public long ID { get; set; }
[DataMember]
public string Name { get; set; }
public int Age { get; set; }
}
或者:
復(fù)制代碼 代碼如下:
public class Staff
{
public long ID { get; set; }
public string Name { get; set; }
[IgnoreDataMember]
public int Age { get; set; }
}
這樣下邊的代碼輸出的結(jié)果就變得和[結(jié)果一]相同了。
復(fù)制代碼 代碼如下:
Staff staff = new Staff() { ID = 1, Name = "xiaozhao" };
var result = staff.ToJson();
最后,我們看下類對象集合的序列化,我們添加職員的聯(lián)系方式如下:
復(fù)制代碼 代碼如下:
List<Contact> listContact = new List<Contact>();
listContact.Add(new Contact() { StaffID = 3, Email = "xiaowang@163.com" });
listContact.Add(new Contact() { StaffID = 4, Email = "xiaoli@163.com" });
每個(gè)職員可能對應(yīng)一個(gè)聯(lián)系方式,這里要考慮有的職員沒有聯(lián)系方式的情況,直接給出代碼:
復(fù)制代碼 代碼如下:
List<string> list = new List<string>();
foreach (var staff in listStaff)
{
JsonObject json = new JsonObject();
json.Add("ID", staff.ID.ToString());
json.Add("Name", staff.Name);
//聯(lián)系方式
var contact = listContact.FirstOrDefault(m => m.StaffID == staff.ID);
if (contact != null)
{
JsonObject jsonContact = new JsonObject();
jsonContact.Add("Email", contact.Email);
//這里注意,將 Contact 對象序列化后的json串添加到了json對象
json.Add("Contact", contact.ToJson());
}
//將json對象序列化再添加到list
list.Add(json.ToJson());
}
//得到最終json串
var result = string.Format("[{0}]", string.Join(",", list));
得到的 json:
復(fù)制代碼 代碼如下:
[
{
"ID": 2,
"Name": "小李"
},
{
"ID": 3,
"Name": "小王",
"Contact": {
"StaffID": 3,
"Email": "xiaowang@163.com"
}
}
]
而反序列化時(shí),使用 FromJson() 即可:
var staff = result.FromJson<List<Staff>>();
本文簡單介紹了下使用 ServiceStack.Text 來序列化 json,希望對沒有使用過的朋友有些幫助。
到此,關(guān)于“如何使用 ServiceStack.Text 序列化 json”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。