当前位置:  编程技术>WEB前端

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

    来源: 互联网  发布时间:2014-08-25

    本文导语:  代码如下: ///         /// Json序列化,用于发送到客户端        ///         public static string ToJsJson(this object item)        {             DataContractJsonSerializer serializer = new DataContractJsonSerializer(item.GetType());      ...

代码如下:

 ///
        /// Json序列化,用于发送到客户端
        ///
        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();

            }

        }

        ///
        /// Json反序列化,用于接收客户端Json后生成对应的对象
        ///
        public static T FromJsonTo(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();

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

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Symbian上的JSON解析库 s60-json-library
  • Symbian上的JSON解析库 s-json
  • JSON解析器 fasterjson
  • JSON解析包 libjson
  • php解析json数据实例
  • C++的JSON解析类 JSONVALUE
  • Qt的JSON解析库 Qjson
  • JSON解析器 SPJson
  • C#解析JSON实例
  • JSON 解析器 YAJL
  • Symbian上的JSON解析器 sjson
  • HTML标签参考手册 iis7站长之家
  • PHP的XML和JSON数据解析和缓存包 coreylib
  • python解析json实例方法
  • PHP json_decode函数详细解析
  • java的json解析类库使用示例
  • jquery解析多维Json格式数据的例子
  • jquery JSON的解析方式示例介绍
  • 解析JSON对象与字符串之间的相互转换
  • jquery解析JSON数据示例代码
  • Python中实现json字符串和dict类型的互转
  • 高性能JSON库 commons.json
  • JSON标签库 JSON-taglib
  • json用法小结 json数据格式
  • PHP的JSON开发包 Services_JSON
  • JSON压缩算法 JSON.hpack
  • JSON改进版 JSON5
  • 把JSON转换成CSV json2csv
  • JSON-RPC框架 JSON-RPC-Java
  • JSON处理类库 json-smart
  • json数据的列循环 JS循环遍历JSON数据


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3