我希望每个用户只有 1 个会话。但是当我运行 ajax 查询时,系统会生成一个新的会话。当我在我的计算机上以调试模式测试它时没有问题。问题仅出现在分布式应用程序的客户端站点中。
ASP页面:
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
<input id="Text1" type="text" /><br />
<asp:Button ID="btn_ASP" runat="server" onclick="btn_ASP_Click" Text="Asp" />
<input id="btn_JS" type="button" value="JS" onclick="GetUsersList();" /><br />
生成“ConnectCount”会话元素的 Asp 按钮:
protected void btn_ASP_Click(object sender, EventArgs e)
{
int count;
if (HttpContext.Current.Session["ConnectCount"] == null)
count = 1;
else
count = (int)HttpContext.Current.Session["ConnectCount"] + 1;
HttpContext.Current.Session["ConnectCount"] = count;
TextBox1.Text = count.ToString();
}
网络服务代码:
[WebMethod(EnableSession = true)]
[ScriptMethod]
public string Get_UsersList2()
{
int count;
if (HttpContext.Current.Session["ConnectCount"] == null)
count = 1;
else
count = (int)HttpContext.Current.Session["ConnectCount"] + 1;
HttpContext.Current.Session["ConnectCount"] = count;
return count.ToString();
}
对 Web 服务的 Ajax 查询
function GetUsersList() {
$.ajax({
url: '/WbSrv_ACTR.asmx/Get_UsersList2',
type: "POST",
contentType: "application/json; charset=utf-8",
data: '{}',
success: function (data, st) {
if (st == "success") {
if (data.d != "") {
text1.value = data.d;
}
else {
}
}
},
error: function () {
alert("Cannot get list of users");
}
});
}
按钮中的代码只是将 1 添加到 Session["ConnectCount"]。
因此,当我在 Asp 按钮上单击 5 次并在 JQ 按钮上单击 1 次(在本地 IIS 上 - 测试):
result: asp = 5, jq = 6 (correct)
在服务器 IIS 7.5 上执行相同的操作:
result: asp = 5, jq = 1 (incorrect)
服务器使用其他会话。用于测试 - 我通过 ASP 按钮在 Session 中添加了一些元素,但在 Web 服务中找不到它们(那里的 Session 是空的,但SessionID 是相同的)
任何人都可以有解决方案或解决方法吗?
网页配置:
<system.web>
<compilation debug="true" targetFramework="4.0">
<assemblies>
<add assembly="System.Data.Entity, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
</assemblies>
</compilation>
<customErrors mode="Off" />
<authorization>
<deny users="?" />
</authorization>
</system.web>
<system.webServer>
<security>
<authentication>
<windowsAuthentication enabled="true" />
<anonymousAuthentication enabled="false" />
</authentication>
</security>
</system.webServer>