我尝试将参数发送到 asmx(Web 服务文件),但我收到有关“System.InvalidOperationException:缺少参数”的错误。请帮我解决这个问题,非常感谢
这是我的ajax函数
$("#dd_address").change(function () {
var rowID = $(this).find(':selected').val();
console.log(rowID);
$.ajax({
url: "WebService.asmx/queryCity",
data: {
id: JSON.stringify(rowID),
},
type: "POST",
dataType: "json",
contentType: "application/json; charset-utf-8",
success: OnSuccess,
error: OnError
});
});
这是我的asmx代码
DataTable result;
[WebMethod(EnableSession = true)]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public string queryCity(string id)
{
DataTable dt;
SqlConnection MRK_Conn = new SqlConnection(@"Data Source=192.168.24.30;Initial Catalog=Marketing_Data;Persist Security info=True;User ID=sa;Password=sa");
SqlCommand cmd = new SqlCommand();
SqlDataReader sql_dr;
System.Web.Script.Serialization.JavaScriptSerializer serializer = new System.Web.Script.Serialization.JavaScriptSerializer();
MRK_Conn.Open();
cmd = new SqlCommand("select [City RowID], [City Description] from City where [Des Ref Province] = '" + id + "'", MRK_Conn);
dt = new DataTable();
sql_dr = cmd.ExecuteReader();
dt.Load(sql_dr);
sql_dr.Close();
MRK_Conn.Close();
result = dt;
return serializer.Serialize(result);
}
在网络配置文件中
<webServices>
<protocols>
<add name="HttpGet"/>
<add name="HttpPost"/>
</protocols>
</webServices>
最佳答案
您的代码中的问题在于您将输入参数传递给方法的方式,将其更改为:-
var rowID = { "id" : $(this).find(':selected').val() };
然后,在方法中像这样传递它:-
data : JSON.stringify(rowID)
除此之外,您的 ADO.NET 代码对 SQL Injection 开放攻击,所以请改用参数化查询。
关于c# - 系统.InvalidOperationException : Missing parameter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29373340/