【问题标题】:Backend not accepting my JSON object后端不接受我的 JSON 对象
【发布时间】:2015-02-06 18:37:33
【问题描述】:

由于某种原因,这个 AJAX 程序不接受我的 json 对象。

我有一个由 registerdb 访问的 mdf 文件,我确信它是正确的。

它有 3 列:ids、用户名和密码填充数据。

任何帮助将不胜感激。

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script type="text/javascript">
    $(document).ready(function () {
        $("#<%= btn.ClientID %>").click(function () {
            var User = $("#<%= txtuser.ClientID %>").val();
            var Pass = $("#<%= txtpass.ClientID %>").val();
            var data = "{ Username: " + User + ", Password: " + Pass + " }"
            var json1 = JSON.stringify(data);
            $.ajax({
                type: "POST",
                contentType: "application/json; charset=utf-8",
                url: "Default.aspx/Login",
                data: json1,
                dataType: "json",
                success: function (result) {
                    $("#<%= txtid.ClientID %>").val(result.d);
                },
                error: function (Msg) {
                    $("#<%= lblError.ClientID %>").text('failed:' + Msg.status + ':' + Msg.responseText);

                }
            }); return false;
        }); 
    });
</script>

默认.aspx.cs

[System.Web.Services.WebMethod]
public static string Login(string Username,string Password) 
{
    string ids="";
    string connStr = ConfigurationManager.ConnectionStrings["registerdb"].ConnectionString;
    string cmdStr = "SELECT [ids] FROM [register] WHERE [username]=@username AND [password]=@password;";
    try
    {
        using (SqlConnection conn = new SqlConnection(connStr))
        {
            using (SqlCommand cmd = new SqlCommand(cmdStr, conn))
            {
                conn.Open();
                cmd.Parameters.AddWithValue("@username", Username);
                cmd.Parameters.AddWithValue("@password", Password);
                using (SqlDataReader rdr = cmd.ExecuteReader())
                {
                    if (rdr.Read())
                    {
                        ids = rdr[0].ToString();
                    }
                }
                if (ids == "") { ids = "No Match"; };
                conn.Close();
                cmd.Dispose();
                conn.Dispose();
            }
        }
    }
    catch (Exception ex)
    {
        Console.WriteLine(ex.ToString());
    } 
    return ids;  
}

错误代码:

失败:500:{"Message":"无法将类型 \u0027System.String\u0027 的对象转换为类型 \u0027System.Collections.Generic.IDictionary`2[System.String,System.Object]\u0027"," StackTrace":" 在 System.Web.Script.Serialization.ObjectConverter.ConvertObjectToTypeInternal(对象 o,类型类型,JavaScriptSerializer 序列化程序,布尔 throwOnError,Object\u0026 convertObject)\r\n 在 System.Web.Script.Serialization.ObjectConverter.ConvertObjectToTypeMain (对象 o,类型类型,JavaScriptSerializer 序列化程序,布尔 throwOnError,Object\u0026 转换对象)\r\n 在 System.Web.Script.Serialization.JavaScriptSerializer.Deserialize(JavaScriptSerializer 序列化程序,字符串输入,类型类型,Int32 depthLimit)\r\ n 在 System.Web.Script.Serialization.JavaScriptSerializer.Deserialize[T](字符串输入)\r\n 在 System.Web.Script.Services.RestHandler.GetRawParamsFromPostRequest(HttpContext 上下文,JavaScriptSerializer 序列化程序)\r\n 在 System。 Web.Script.Services.RestHandler.GetRawParams(WebServiceMethodDa ta methodData, HttpContext context)\r\n at System.Web.Script.Services.RestHandler.ExecuteWebServiceCall(HttpContext context, WebServiceMethodData methodData)","ExceptionType":"System.InvalidOperationException"}

【问题讨论】:

    标签: asp.net ajax json serialization


    【解决方案1】:

    您的问题是您传递给JSON.stringify 的数据是字符串,而不是JSON 对象。你应该这样做:

    var data = {Username:User, Password:Pass};
    var json1 = JSON.stringify(data);
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-09-11
      • 2021-07-15
      • 2020-05-02
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多