在asp.net中序列化为JSON?

时间:2013-03-27 09:26:12

标签: c# jquery ajax json

我在asp.net第一次使用JSON

我有像我这样的WebMethod

               [WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public static string Vo_Get(string Action,int ID)
{
    Product p= new Product();

    DataSet ds= new DataSet();

    p.Action = Action;
    p.ID= ID;

    ds= VoGet_Get(obj);

    **string jsonVesselDetails = JsonConvert.SerializeObject(ds, Formatting.None);
    return jsonVesselDetails;**
}

这里我得到了我的结果

       [
  {
    "Pinky": 1,
    "Ponky": "Breakwater Dockk",

  },
  {
    "Pinky": 2,
    "Ponky": "Watson Island Dock",    
  },

但是,当我尝试使用Ajax调用并附加到表时,如果我尝试使用结果绑定并且如果我尝试使用result.data绑定则给出Unexpexted Token U

最后我发现问题在于序列化,

我的Ajax调用是

                  $.ajax({
                type: "POST",
                contentType: "application/json; charset=utf-8",
                url: "Voyage.aspx/Vo_Get",
                data: "{'Action':'Get','ID':'68'}",
                dataType: "json",
                success: function (data) {
                    try {
                        alert("getdata! success" );

                        Get(data);

                    } catch (ex) {
                        alert(ex);
                    }
                },
                error: function (msg) {
                    alert("err: " + error);
                }
            });

3 个答案:

答案 0 :(得分:0)

我不知道GetVessels期待什么,但尝试:

GetVessels(data.d);

即。传递实际数据而不是整个响应对象。

答案 1 :(得分:0)

也许您在成功函数中使用相同的变量data。 尝试使用以下内容,

success: function (result) {
   try {
        alert("getdata! success" );

        GetVessels(result);

        //Rebuild the table
        //BuildVesselTaggerInfo();

   } catch (ex) {
        alert(ex);
   }
},

请注意,我已从数据更改为结果。

答案 2 :(得分:0)

首先验证您的JSON方法所期望的GetVessles或数组结构类型。

您可以通过直接提供VoyageVessel_Get方法的JSON响应或手动构建它来实现。即。

 var data= [
 {
      "TerminalID": 1,
      "TerminalName": "Breakwater Dockk",
      "PortID": 1,
      "PortName": "Swire Pacific Offshore",
      "Column1": "08/03/13",
      "Column2": "16/03/13",
      "ServiceID": 2
  },
  {
      "TerminalID": 2,
      "TerminalName": "Watson Island Dock",
      "PortID": 2,
      "PortName": "Keppel Offshore",
      "Column1": "20/03/13",
      "Column2": "23/03/13",
      "ServiceID": 2
  }];

  GetVessels(data);

查看您的GetVessels是否适用于此对象。如果没有,那么找出它需要什么样的结构(只有你能做到),并构建它。

其次,您无法直接访问:successASP.NET Web-Service的回复。

像这样访问它:

success: function (data) {
           var jsonData= data.d;
           GetVessels(jsonData);
 }

更新

如果您的对象由datetime字段组成,请尝试在Serialization中指定DateFormathandling,即

JsonSerializerSettings microsoftDateFormatSettings = new JsonSerializerSettings
            {
                DateFormatHandling = DateFormatHandling.MicrosoftDateFormat
            };
string serializedObject= Newtonsoft.Json
                     .JsonConvert
                     .SerializeObject(dsVoyages, microsoftDateFormatSettings);