国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Json序列化和反序列化方法解析

2019-11-20 21:25:49
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

 /// <summary>
        /// Json序列化,用于發送到客戶端
        /// </summary>
        public static string ToJsJson(this object item)
        {

            DataContractJsonSerializer serializer = new DataContractJsonSerializer(item.GetType());

            using (MemoryStream ms = new MemoryStream())
            {

                serializer.WriteObject(ms, item);

                StringBuilder sb = new StringBuilder();

                sb.Append(Encoding.UTF8.GetString(ms.ToArray()));

                return sb.ToString();

            }

        }

        /// <summary>
        /// Json反序列化,用于接收客戶端Json后生成對應的對象
        /// </summary>
        public static T FromJsonTo<T>(this string jsonString)
        {

            DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T));

            MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(jsonString));

            T jsonObject = (T)ser.ReadObject(ms);

            ms.Close();

            return jsonObject;

        }


實體類
復制代碼 代碼如下:

    [DataContract]
    public class TestObj
    {
        [DataMember]
        public string make { get; set; }
        [DataMember]
        public string model { get; set; }
        [DataMember]
        public int year { get; set; }
        [DataMember]
        public string color { get; set; }
    }

------------------javascript獲取Json--------------------

javascript調用測試代碼

復制代碼 代碼如下:

$('#getJson').click(function() {
                $.ajax({
                    url: "getJsonHandler.ashx",
                    type: 'GET',
                    data: {},
                    dataType: 'json',
                    timeout: 1000,
                    error: function(XMLHttpRequest, textStatus, errorThrown) { alert(textStatus) },
                    success: function(result) {

                        alert(result.make);
                        alert(result.model);
                        alert(result.year);
                        alert(result.color);
                    }

                });
            });


C#后臺生成代碼
復制代碼 代碼如下:

public class getJsonHandler: IHttpHandler
    {
public void ProcessRequest(HttpContext context)
        {
            TestObj obj = new TestObj();

            obj.make = "Make is Value";
            obj.model = "Model is Value";
            obj.year = 999;
            obj.color = "Color is Value";

            context.Response.Write(obj.ToJsJson());
        }
 public bool IsReusable
        {
            get
            {
                return false;
            }
        }
}

//返回值為 {"color":"Color is Value","make":"Make is Value","model":"Model is Value","year":999}


-----------------C#由Json生成對象-----------------------

javascript調用測試代碼

復制代碼 代碼如下:

           $('#postJson').click(function() {

                var m_obj = { make: "Dodge", model: "Coronet R/T", year: 1968, color: "yellow" };
                var jsonStr = JSON.stringify(m_obj); //用Json2.js生成Json字符串

                $.ajax({
                    url: "postJsonHandler.ashx",
                    type: 'POST',
                    data: { postjson: jsonStr },
                    dataType: 'json',
                    timeout: 1000,
                    error: function(XMLHttpRequest, textStatus, errorThrown) { alert(textStatus) },
                    success: function(result) {

                        alert(result.success);
                    }

                });
});


C#后臺生成代碼
復制代碼 代碼如下:

public class postJsonHandler: IHttpHandler
    {
        public void ProcessRequest(HttpContext context)
        {
            string jsonStr = context.Request["postjson"];

            TestObj obj = jsonStr.FromJsonTo<TestObj>();

            if (string.IsNullOrEmpty(obj.make) || string.IsNullOrEmpty(obj.model) || string.IsNullOrEmpty(obj.color)

|| obj.year < 0)
            {
                context.Response.Write("{success:false}");
            }
            else
            {
                context.Response.Write("{success:true}");
            }

public bool IsReusable
        {
            get
            {
                return false;
            }
        }
}


使用Json時需要注意,服務器端拼湊生成Json字符串時,一定要注意把字符串用/"/"包裹,不然客戶端接收時肯定會報錯,根據Json字符串生成對象,是根據對應的名稱賦值,多于或少于都不會報錯.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 寻甸| 牙克石市| 德昌县| 自治县| 聊城市| 万宁市| 滦平县| 仁怀市| 高雄县| 苍山县| 华坪县| 三河市| 庆安县| 丽水市| 淮阳县| 当涂县| 海阳市| 陇川县| 永仁县| 石狮市| 健康| 黔江区| 湟源县| 惠东县| 沂南县| 台山市| 阿拉尔市| 孝感市| 霍城县| 梅河口市| 丹棱县| 盖州市| 象山县| 郴州市| 凤山市| 梁山县| 武安市| 天峨县| 奉贤区| 旬邑县| 南通市|