经过一个多星期的研究,各种查找资料终于自己实现了Jquery  Ajax Json ashx 的前后台数据交流功能

首先一点,Ajax只能对应一个ashx文件,多余两个,如果打开异步传输的async: true,第二个无法返回数据。

第二post和get的方式除了w3shcool中说的HTTP 方法:GET 对比 POST,在后台的代码上也有一定的区分

使用Jquery封装的Ajax比较简单,Json需要解析。

1.新建类Jsonconvert.cs,用于Json的解析和转换

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Json;
using System.ServiceModel.Web;
using System.IO;//MemoryStream
using System.Text;//StringBuilder

/// <summary>
/// Json 的摘要说明
/// </summary>
public static class Jsonconn
{
    

    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;

    }
}
View Code

相关文章: