0

我有一个独立的 .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 代码正常工作,但在再次重置应用程序池之前不会反映进一步的更新。

4

1 回答 1

0

我从另一个我似乎找不到链接的答案中抓住了这个,但您不需要重置整个应用程序池!我有一个使用 AJAX 从 Web 服务中提取数据的 ASMX 文件。我快疯了,因为更新 Web 服务并没有更改网页正在提取的数据。

将此添加到页面加载后面的代码中,它将清除缓存并使用新更新的 Web 服务:

Response.Cache.SetCacheability(HttpCacheability.NoCache);
Response.Cache.SetExpires(DateTime.Now);
Response.Cache.SetNoServerCaching();
Response.Cache.SetNoStore();

这正是我需要的,但我认为我真的只需要该SetExpires行来清除此页面的缓存。

于 2013-05-09T19:46:16.757 回答