zoukankan      html  css  js  c++  java
  • Net 3.5 用DataContractJsonSerializer实现Json序列和反序列例子

    近来在研究jQuery,用$.ajax在与后台交换数据时用到Json格式,后台与前台序列化和反序列化方法研究了很久才成功,发文共享.

    前台调用的JS文件需要用到jQuery-1.2.6.jsjson2.js,后台引用空间System.Runtime.SerializationSystem.Runtime.Serialization.Json


    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 { getset; }
            [DataMember]
            
    public string model { getset; }
            [DataMember]
            
    public int year { getset; }
            [DataMember]
            
    public string color { getset; }
        }
    复制代码

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

  • 相关阅读:
    四、分布式账本技术对比
    二、主流区块链技术特点及Hyperledger Fabric V0.6版本特点
    一、Bitcoin比特币与BlockChain区块链技术
    java-信息安全(十七)-*.PFX(*.p12)&个人信息交换文件
    java-信息安全(十五)-单向认证
    java-信息安全(十六)-双向认证
    java-信息安全(十四)-初探SSL
    java-信息安全(十二)-数字签名【Java证书体系实现】
    java-信息安全(十三)-数字签名,代码签名【Java证书体系实现】
    移动端网页 rem css书写
  • 原文地址:https://www.cnblogs.com/bdzwater/p/2615824.html
Copyright © 2011-2022 走看看