JSON无效的原语

时间:2015-01-29 03:34:41

标签: c# jquery ajax json asp.net-ajax

我想在功能测试()中将我的座位数传递给TryJSIN.aspx。 但我有错误,当我使用类型' GET'然后我有错误

  

"无效的JSON原语:1-9。"

1-9是noSeat值。 但是当我改为' POST'我有错误

  

尝试调用方法' test'使用POST请求,这是不允许的。

请检查我的以下代码。这是我使用get type

的时候
  var sid = jQuery(this).attr('id');
    $.ajax({
        url: "TryJSON.aspx/test",
        type: "GET",
        data: {noSeat: sid},
        contentType: "application/json; charset=utf-8",

        success: function (response) {
          // var arr = JSON.parse(response.d);
            console.log(arr);            
        },
        error: function () {
            alert("sorry, there was a problem!");
            console.log("error");
        },
        complete: function () {
            console.log("completed");
        }

    }); 

以及当我使用POST类型

时的ajax
var sid = jQuery(this).attr('id');
    $.ajax({
        url: "TryJSON.aspx/test",
        type: "POST",
        data: JSON.stringify({'noSeat': sid}),
        contentType: "application/json; charset=utf-8",
        success: function (response) {
          // var arr = JSON.parse(response.d);
            console.log(arr);            
        },
        error: function () {
            alert("sorry, there was a problem!");
            console.log("error");
        },
        complete: function () {
            console.log("completed");
        }

    });

这是我的c#代码

[WebMethod]
    [ScriptMethod(UseHttpGet = true)]
    public static string test(string noSeat)
    {
        return noSeat;
    }

请帮帮我。我是c#ajax和jQuery的新手。所以我需要很多帮助

更新 我在第一次评论后编辑我的代码。但它显示相同。

[WebMethod]
    [ScriptMethod(UseHttpGet = true)]
    public static string test(string noSeat)
    {
        JavaScriptSerializer serializer = new JavaScriptSerializer();
        return serializer.Serialize(noSeat).ToString();
    }

1 个答案:

答案 0 :(得分:0)

当我使用POST时,我不允许使用[ScriptMethod(UseHttpGet = true)],因为它适用于GET类型。然后,当我使用JSON.stringify时,数据必须使用contentType: "application/json; charset=utf-8",因为它认为我发送JSON而我发送字符串数据。所以我需要先将它转换为JSON。

var sid = jQuery(this).attr('id');
    //console.log(sid);
    $.ajax({
        url: "TryJSON.aspx/test",
        type: "post",
        data: JSON.stringify({ 'noSeat': sid }),
        contentType: "application/json; charset=utf-8",
        success: function (response) {
            var arr = JSON.parse(response.d);
            objData = new Array();
            objData = arr;
            for (i = 0; i < objData.length; i++)
            {                 
                alert(objData[i].noBooking +" "+ objData[i].noSeat);
            }                                           
        },
        error: function () {
            alert("sorry, there was a problem!");
            console.log("error");
        },
        complete: function () {
            console.log("completed");
        }

这是如何解决C#

[WebMethod]
   // [ScriptMethod(UseHttpGet = true)]
    public static string test(string noSeat)
    {
        SqlConnection conn = DBConnection.getConnection();
        SqlCommand cmd;
        SqlDataReader dr;
        conn.Open();
        string sql = "Select noBooking,noSeat FROM booking WHERE noSeat = '" + noSeat +"' AND statusBooked = 1";
        cmd = new SqlCommand(sql, conn);
        dr = cmd.ExecuteReader();
        List<booking> BookList = new List<booking>();
        while (dr.Read())
        {
            booking bookClass = new booking();
            bookClass.noBooking =(int)dr[0];
            bookClass.noSeat = dr[1].ToString();
            BookList.Add(bookClass);
        }
        JavaScriptSerializer serializer = new JavaScriptSerializer();
        return serializer.Serialize(BookList).ToString();
    }