我有一个独立的 .ASPX 页面(后面没有代码),它包含一个简单的 WebMethod,我通过 JQuery Ajax 调用它。见下文:
(请注意这是概念验证代码,而不是生产代码!)
<!DOCTYPE html>
<%@ Page Language="C#" %>
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SqlClient" %>
<html>
<head runat="server">
<title>Untitled</title>
<script runat="server" type="text/c#">
[System.Web.Services.WebMethod]
public static int GetData(int Id)
{
string connectionString = "Data Source=xxx;Initial Catalog=xxx;User Id=xxx;Password=xxx;";
using (SqlConnection connection = new SqlConnection(connectionString))
{
string query = "SELECT AVG(Number) FROM Data WHERE ID = @Id;";
using (SqlCommand command = new SqlCommand(query, connection))
{
command.Parameters.AddWithValue("@Id", Id);
connection.Open();
return (int)command.ExecuteScalar();
}
}
}
</script>
<script src="http://code.jquery.com/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">
function getAvg() {
$.ajax({
type: 'POST',
url: "WebMethodAjaxExample.aspx/GetData",
data: JSON.stringify({Id: $('#tbId').val()}),
contentType: 'application/json',
success: function (data, textStatus) {
$('#theParagraph').text(data.d);
}
})
}
</script>
</head>
<body>
<div>
<input type="text" id="tbId" />
<button onclick="getAvg()">Go</button>
</div>
<p id="theParagraph"></p>
</body>
</html>
我已经理智地检查了 SQL 查询,并且知道它返回一个 FLOAT(七位和一位)。但是,如您所见,我的 WebMethod 返回一个 int。因此,我的页面总是四舍五入。
我决定将 WebMethod 返回类型和 ExecuteScalar 转换为 Double。但是页面仍然返回“7”。
经过一番修改,我了解到的最有趣的事实是,当我决定将 C# 代码中的 WebMethod 名称更改为 GetDatum,并对 JQuery Ajax 函数名称进行相关更改时,这次运行页面我得到了回报来自 Ajax 调用的状态 500,错误消息为“未知 Web 方法”。
感觉页面没有像我期望的那样被动态重新编译,而是仍然使用缓存版本,即使请求标头状态为“无缓存”。
如果有任何帮助,该页面托管在 Sharepoint 2010 中。
谁能明白发生了什么?
更新:回收应用程序池可以使最新的 WebMethod 代码正常工作,但在再次重置应用程序池之前不会反映进一步的更新。