Json.NET的簡單介紹
首先介紹一個為方便在.NET中使用JSON的API,Json.NET。它方便我們讀取從瀏覽器流向服務(wù)器的JSON對象,也方便在響應(yīng)流中寫入JSON對象。
Json.NET只提供了服務(wù)器端的方法,主要有實現(xiàn)JSON文本與XML互相轉(zhuǎn)換的類,有自定義讀寫JSON的JsonReader類和JsonWriter類,還有一個非自定義讀寫JSON的JavaScriptSerializer類。
ASP.NET AJAX中,服務(wù)器端由JavaScriptSerializer類的幾個方法來用于實現(xiàn)序列化和反序列化能力。在Json.NET中,服務(wù)器端的序列化和反序列化能力則主要由JavaScriptConvert類的幾個方法提供。本篇的例子只使用了JavaScriptConvert。
JavaScriptConvert
Json.NET中,這個類用于序列化和反序列化JavaScript對象。
這個類有兩個方法:
- SerializeObject(object value, params JsonConverter[] converters),序列化,它有個重載方法SerializeObject(object value)
- DeserializeObject(string value, Type type),反序列化,它有個重載方法DeserializeObject(string value)
在客戶端,Json.NET未提供支持。
下面我們嘗試用這個API在ASP.NET中實現(xiàn)用JSON交互數(shù)據(jù)。
使用Json.NET在C/S中交互JSON數(shù)據(jù)的簡單例子
1、先新建一個ASP.NET 網(wǎng)站。
2、將下載到的Binary文件夾中的Newtonsoft.Json.dll和Newtonsoft.Json.XML放入網(wǎng)站的bin文件,當(dāng)然要先新建bin文件夾。然后對dll添加引用。
3、切換到設(shè)計模式,從標(biāo)準(zhǔn)工具箱向頁面上添加三個Label,Text分別為EmployeeID、EmployeeName、EmployeeInfo;三個Textbox,ID分別為txtID、txtName、txtInfo;然后添加一個Button,ID為btnToJSONString,Text為Invoke ToJSONString;然后添加一個Textbox,ID為txtJSON,Textmode為MultiLine,rows設(shè)為5;接著再分別添加一個Button和Textbox,ID為btnToObject、txtStrEmployee,Button的Text為Invoke ToStrEmployee。
4、添加一個WebService項目。
編寫一個Employee類,然后兩個WebMethod,接著在項目中對該Web服務(wù)添加引用。代碼如下:
using System;
using System.Web;
using System.Collections;
using System.Web.Services;
using System.Web.Services.Protocols;
using Newtonsoft.Json;
class Employee
{
private string[] employeeInfo;
public int EmployeeID;
public string EmployeeName;
public string[] EmployeeInfo
{
get { return this.employeeInfo; }
set { this.employeeInfo = value;}
}
}
/**//// summary>
/// WebService 的摘要說明
/// /summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class WebService : System.Web.Services.WebService {
public WebService () {
//如果使用設(shè)計的組件,請取消注釋以下行
//InitializeComponent();
}
[WebMethod]
public string ToJSONString(int employeeID, string employeeName, string[] employeeInfo)
{
Employee employee = new Employee();
employee.EmployeeID = employeeID;
employee.EmployeeName = employeeName;
employee.EmployeeInfo = employeeInfo;
return JavaScriptConvert.SerializeObject(employee);
}
[WebMethod]
public string ToStrEmployee(string strJSON)
{
Employee decerializedEmployee = (Employee)JavaScriptConvert.DeserializeObject(strJSON, typeof(Employee));
return "ID: " + decerializedEmployee.EmployeeID + " "
+ "Name: " + decerializedEmployee.EmployeeName + " "
+ "Info: " + decerializedEmployee.EmployeeInfo.ToString();
}
}
成員的屬性類型分別為數(shù)字、字符串和數(shù)組。
5、對兩個Button編寫事件代碼
protected void btnToJSONString_Click(object sender, EventArgs e)
{
MyServ.WebService MyWebServ = new MyServ.WebService();
string employeeJSON = MyWebServ.ToJSONString(Int32.Parse(txtID.Text), txtName.Text, txtInfo.Text.Split(','));
txtJSON.Text = employeeJSON;
}
protected void btnToStrEmployee_Click(object sender, EventArgs e)
{
MyServ.WebService MyWevServ = new MyServ.WebService();
string strEmployee = MyWevServ.ToStrEmployee(txtJSON.Text);
txtStrEmployee.Text = strEmployee;
}
6、按Ctrl + F5運(yùn)行;在EmployeeID、EmployeeName、EmployeeInfo中輸入123、Hunts.C及一些個人信息(用逗號隔開);點(diǎn)擊Invoke ToJSONString,經(jīng)服務(wù)器端序列化后,結(jié)果在txtJSON文本框中;然后點(diǎn)擊Invoke ToStrEmployee,此時txtJSON文本框中的JSON文本傳輸給服務(wù)器端,服務(wù)器端讀取該JSON并反序列化成對象,而后在txtStrEmployee中寫入Employee的成員值。
在ASP.NET中如何使用JSON就介紹到這里,希望這篇文章對大家的學(xué)習(xí)有所幫助。
您可能感興趣的文章:- js遍歷json的key和value的實例
- 微信小程序通過api接口將json數(shù)據(jù)展現(xiàn)到小程序示例
- Bootstrap 填充Json數(shù)據(jù)的實例代碼
- 簡單談?wù)凪ySQL5.7 JSON格式檢索
- ASP.NET中實現(xiàn)把Json數(shù)據(jù)轉(zhuǎn)換為ADO.NET DataSet對象
- Asp.net配合easyui實現(xiàn)返回json數(shù)據(jù)實例
- ASP.NET中MVC使用AJAX調(diào)用JsonResult方法并返回自定義錯誤信息
- .Net基于MVC4 Web Api輸出Json格式實例
- 淺談C#.NET、JavaScript和JSON
- js實現(xiàn)將json數(shù)組顯示前臺table中