C#處理JSON 數據


https://blog.csdn.net/qq_34897745/article/details/80562518

網絡中數據傳輸經常是xml或者json

在一般的開發過程中會經常遇到這樣的問題,在別的地方獲取的數據接口自己箱拿過來用,會遇見一下幾個問題,跨域,拿過來的數據個數不是自己想要的,

1.跨域:

1-1:跨域的解決辦法又很多種,前端的js處理

1-2:后台進行處理,一般建議后台處理最好這樣的話可以吧相關的數據格式進行處理

 

一、C#處理簡單json數據
json數據:

{"result":"0","res_info":"ok","queryorder_info":"info"}

我這里是以jsonmy1.txt文件的形式保存在d盤json文件夾下。

構造對象:

 public struct ToJsonMy
 {
    public string result { get; set; }  //屬性的名字,必須與json格式字符串中的"key"值一樣。
    public string res_info { get; set; }
    public string queryorder_info { get; set; }  
 }
復制代碼
public static void JsonMy()
{
    string json = Jsonstr("D:\\json\\jsonmy1.txt");//Jsonstr函數讀取json數據的文本txt                
    JavaScriptSerializer js = new JavaScriptSerializer();   //實例化一個能夠序列化數據的類
    ToJsonMy list = js.Deserialize<ToJsonMy>(json);    //將json數據轉化為對象類型並賦值給list
    string result = list.result;             
    string res_info = list.res_info;
    string queryorder_info = list.res_info;
}
復制代碼

二、C#處理包含對象的json數據
json數據:jsonmy2.txt

{"result":"0","res_info":"ok","queryorder_info":{"order_num":"5","orderdetail":"ok"}}


構造對象:

復制代碼
public struct ToJsonMy2
{
    public string result { get; set; } 
    public string res_info { get; set; }
    public queryorder_info queryorder_info;
}
public struct queryorder_info
{
    public string order_num { get; set; }
    public string orderdetail { get; set; }
};
復制代碼

轉換過程:

復制代碼
public static void JsonMy2()
{
    string json = Jsonstr("D:\\json\\jsonmy2.txt");
    JavaScriptSerializer js = new JavaScriptSerializer();   //實例化一個能夠序列化數據的類
    ToJsonMy2 list = js.Deserialize<ToJsonMy2>(json);    //將json數據轉化為對象類型並賦值給list
    string result = list.result;   
    string res_info = list.res_info;
    string order_num = list.queryorder_info.order_num;
    string orderdetail = list.queryorder_info.orderdetail;
}
復制代碼

三、C#處理包含對象、數組的json數據
json數據:jsonmy4.txt

{"result":"0","res_info":"ok","queryorder_info":{"order_num":"5","orderdetail":[{"CFTUin":"769839263","CancelDeadline":"2013-09-12 23:00:00","CheckInDate":"2013-09-12 00:00:00","CheckOutDate":"2013-09-13 00:00:00","CityID":"0101","CurrencyCode":"RMB","HotelID":"00301105","HotelName":"樂家連鎖(北京天壇南門店)(原速8酒店(北京天壇南門店)","ListID":"1000000005201308280002999652","PayAmt":"228","PayType":"0","RommsCnt":"1","SPTransID":"65202157","State":"4"},{"CFTUin":"248486133","CancelDeadline":"2013-10-13 23:00:00","CheckInDate":"2013-10-13 00:00:00","CheckOutDate":"2013-10-18 00:00:00","CityID":"0201","CurrencyCode":"RMB","HotelID":"10201314","HotelName":"上海凱頓酒店","ListID":"1000000005201308280002999413","PayAmt":"1140","PayType":"0","RommsCnt":"1","SPTransID":"65197226","State":"4"}]}}

構造對象:

復制代碼
public struct ToJsonMy3
{
    public string result { get; set; }
    public string res_info { get; set; }
    public queryorder_info queryorder_info;
}
public struct queryorder_info
{
    public string order_num { get; set; }
    public List<orderdetail> orderdetail;//數組處理      
};
public struct orderdetail
{
    public string CFTUin { get; set; }
    public string CancelDeadline { get; set; }
    public string CheckInDate { get; set; }
    public string CheckOutDate { get; set; }
    public string CityID { get; set; }
    public string CurrencyCode { get; set; }
    public string HotelID { get; set; }
    public string HotelName { get; set; }
    public string ListID { get; set; }
    public string PayAmt { get; set; }
    public string PayType { get; set; }
    public string RommsCnt { get; set; }
    public string SPTransID { get; set; }
    public string State { get; set; }
};
復制代碼

轉換過程:

復制代碼
public static void JsonMy4()
{
    string json = Jsonstr("D:\\json\\jsonmy4.txt");
    JavaScriptSerializer js = new JavaScriptSerializer();   //實例化一個能夠序列化數據的類
    ToJsonMy3 list = js.Deserialize<ToJsonMy3>(json);    //將json數據轉化為對象類型並賦值給list
    string result = list.result;    
    string res_info = list.res_info;
    string order_num = list.queryorder_info.order_num;
    List<orderdetail> orderdetail = list.queryorder_info.orderdetail;
    string CFTUin = orderdetail[0].CFTUin;
    string HotelName = orderdetail[0].HotelName;
    string ListID = orderdetail[1].ListID;
    string State = orderdetail[2].State;
}
復制代碼

以上代碼來自:http://www.jb51.net/article/48027.htm

在項目中也遇到了使用JSON的情況,就把轉化過程寫一下。

1.從數據庫獲取的json數據為:

復制代碼
[{"ACTIONVALUE":"-1","CONTENT":"","DEVID":"30000449636001","DEVNAME":"#1空調","DEVTYPE":"46","EVENTTYPE":"","GRIDCODE":"","ISAUTO":"false","MEASURENAME":"通用.低風","MEASURETAG":"GEN.CtrlLowWind","STREAMTYPE":null,"TIMESPAN":""},{"ACTIONVALUE":"0","CONTENT":"","DEVID":"30000449660712","DEVNAME":"#1風機","DEVTYPE":"56","EVENTTYPE":"","GRIDCODE":"","ISAUTO":"false","MEASURENAME":"風機開關","MEASURETAG":"GEN.UnibitCtrl","STREAMTYPE":null,"TIMESPAN":""},{"ACTIONVALUE":"1","CONTENT":"","DEVID":"30000449660710","DEVNAME":"#1警笛","DEVTYPE":"57","EVENTTYPE":"","GRIDCODE":"","ISAUTO":"false","MEASURENAME":"警笛開關","MEASURETAG":"GEN.UnibitCtrl","STREAMTYPE":null,"TIMESPAN":""},{"ACTIONVALUE":"1","CONTENT":"","DEVID":"30000449660708","DEVNAME":"#1燈光","DEVTYPE":"45","EVENTTYPE":"","GRIDCODE":"","ISAUTO":"true","MEASURENAME":"燈光開光","MEASURETAG":"GEN.UnibitCtrl","STREAMTYPE":null,"TIMESPAN":""},{"ACTIONVALUE":"66","CONTENT":"","DEVID":"30000449667767","DEVNAME":"hik1","DEVTYPE":"49","EVENTTYPE":"","GRIDCODE":"110100000103010001","ISAUTO":"true","MEASURENAME":"","MEASURETAG":"GEN.PreSet","STREAMTYPE":"150","TIMESPAN":""},{"ACTIONVALUE":"-1","CONTENT":"","DEVID":"30000449667767","DEVNAME":"hik1","DEVTYPE":"49","EVENTTYPE":"","GRIDCODE":"110100000103010001","ISAUTO":"true","MEASURENAME":"","MEASURETAG":"GEN.VideoRecord","STREAMTYPE":"150","TIMESPAN":""}]
復制代碼

2.構造實體對象:

復制代碼
 public class ActionParam
    {
        //[{"ACTIONVALUE":"1","CONTENT":"","DEVID":"30000449660708","DEVNAME":"#1燈光","DEVTYPE":"45","EVENTTYPE":"","GRIDCODE":"","ISAUTO":"true","MEASURENAME":"燈光開光","MEASURETAG":"GEN.UnibitCtrl","STREAMTYPE":null,"TIMESPAN":""}]
        public int ACTIONVALUE { get; set; }
        public string CONTENT { get; set; }
        public string DEVID { get; set; }
        public string DEVNAME { get; set; }
        public string DEVTYPE { get; set; }
        public string EVENTTYPE { get; set; }
        public string GRIDCODE { get; set; }
        public bool ISAUTO { get; set; }
        public string MEASURENAME { get; set; }
        public string MEASURETAG { get; set; }
        public string STREAMTYPE { get; set; }
        public string TIMESPAN { get; set; }

    }
復制代碼

3.轉化為C#中聲明的數據格式:

 JavaScriptSerializer js = new JavaScriptSerializer();   //實例化一個能夠序列化數據的類
 List<ActionParam> listDetail = js.Deserialize<List<ActionParam>>(actionParam);

以為json字符串是數組格式,所以js.Deserialize<T>()泛型中使用List<ActionParam>.

 

來源:https://www.cnblogs.com/zhangyuanbo12358/p/5590194.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM