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

 更新时间:2013年12月19日 09:45:50   作者:  
本篇文章主要是对Json序列化和反序列化方法进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助

复制代码 代码如下:

 /// <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字符串生成对象,是根据对应的名称赋值,多于或少于都不会报错.

相关文章

  • 全面解析标签页的切换方式

    全面解析标签页的切换方式

    这篇文章主要介绍了标签页的切换方式,介绍的非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08
  • jquery删除数组中重复元素

    jquery删除数组中重复元素

    本文主要讲解jquery删除数组中重复元素的具体思路与示例代码,有助于理解与学习,希望对大家有所帮助
    2016-12-12
  • jquery 步骤进度轴插件的实现代码

    jquery 步骤进度轴插件的实现代码

    今天给大家分享一个jquery插件之步骤进度轴的实现思路,这个功能在一些网站注册账号时一般都会用到,今天就通过实例代码给大家详细介绍下,感兴趣的朋友跟随小编一起看看吧
    2021-05-05
  • 基于jQuery实现仿QQ空间送礼物功能代码

    基于jQuery实现仿QQ空间送礼物功能代码

    qq空间的一份虚拟礼物可能会让很久不曾相见的朋友拉近一些距离。那么基于jquery代码是如何实现此功能的呢?下面脚本之家小编给大家分享基于jQuery实现仿QQ空间送礼物功能代码,一起看看吧
    2016-05-05
  • jquery 利用show和hidden实现级联菜单示例代码

    jquery 利用show和hidden实现级联菜单示例代码

    级联菜单的实现方法有很多,在本文为大家介绍下使用show和hidden轻松实现下级联效果,感兴趣的朋友可以参考下,希望对大家有所帮助
    2013-08-08
  • jQuery中cookie插件用法实例分析

    jQuery中cookie插件用法实例分析

    这篇文章主要介绍了jQuery中cookie插件用法,结合完整实例形式分析了jQuery针对cookie操作的插件jquery.cookie.js相关使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-12-12
  • 密码框显示提示文字jquery示例

    密码框显示提示文字jquery示例

    密码框提示文字的功能还是比较实用的,下面为大家介绍下使用jquery简单的实现下,喜欢的朋友可以参考下
    2013-08-08
  • jQuery中[attribute=value]选择器用法实例

    jQuery中[attribute=value]选择器用法实例

    这篇文章主要介绍了jQuery中[attribute=value]选择器用法,实例分析了[attribute=value]选择器的功能、定义及给定属性及属性值元素的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2014-12-12
  • jquery 实现两Select 标签项互调示例代码

    jquery 实现两Select 标签项互调示例代码

    这篇文章主要与大家分享了jquery实现两Select标签项互调的具体实现,比较简单,比较实用
    2014-09-09
  • jQuery仿淘宝网产品品牌隐藏与显示效果

    jQuery仿淘宝网产品品牌隐藏与显示效果

    这篇文章主要介绍了jQuery仿淘宝网产品品牌隐藏与显示效果,通过jquery鼠标事件实现页面元素的显示与隐藏功能,非常具有实用价值,需要的朋友可以参考下
    2015-09-09

最新评论