C# JSON无效原语
我想在功能测试中将我的座位号传递给TryJSIN.aspx。 但我有错误,当我使用类型“GET”时,我就有错误 无效的JSON原语:1-9 1-9等于零。 但当我改为“POST”时,我有一个错误 试图使用POST请求调用方法“test”,这是不允许的 请检查我的以下代码。这是我使用get type的时候C# JSON无效原语,c#,jquery,ajax,json,asp.net-ajax,C#,Jquery,Ajax,Json,Asp.net Ajax,我想在功能测试中将我的座位号传递给TryJSIN.aspx。 但我有错误,当我使用类型“GET”时,我就有错误 无效的JSON原语:1-9 1-9等于零。 但当我改为“POST”时,我有一个错误 试图使用POST请求调用方法“test”,这是不允许的 请检查我的以下代码。这是我使用get type的时候 var sid = jQuery(this).attr('id'); $.ajax({ url: "TryJSON.aspx/test", 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;
}
请帮帮我。我对cjax和jQuery相当陌生。所以我需要很多帮助
更新:
我在第一次注释后编辑代码。但它显示了同样的情况
[WebMethod]
[ScriptMethod(UseHttpGet = true)]
public static string test(string noSeat)
{
JavaScriptSerializer serializer = new JavaScriptSerializer();
return serializer.Serialize(noSeat).ToString();
}
当我使用POST时,我不允许使用[ScriptMethodUseHttpGet=true],因为它用于GET类型。当我使用contentType:application/JSON时,数据必须使用JSON.stringify;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();
}
您没有返回JSON。我曾经使用JSON序列化程序,但它仍然错误,并带有相同的注释@SLaksWhat response body,您在开发工具中看到了什么?