c#-使用$.ajax同时运行多个WebRequest
作者:互联网
我有2个MVC应用程序需要连接到第3个应用程序.导致问题的代码在两个MVC应用程序中都是相同的.
public bool UpdateServerData()
{
//string BASE_URL = "http://";
string BASE_URL = "http://localhost:55094";
string url = BASE_URL + "/Home/PullLiveData";
WebRequest wr = WebRequest.Create(url);
wr.Credentials = CredentialCache.DefaultNetworkCredentials; // uses current windows user
var response = (HttpWebResponse)wr.GetResponse();
return true;
}
public ActionResult GetServerUpdateProgress()
{
//string BASE_URL = "http://";
string BASE_URL = "http://localhost:55094";
string url = BASE_URL + "/Home/UpdateProgress";
WebRequest wr = WebRequest.Create(url);
wr.Credentials = CredentialCache.DefaultNetworkCredentials; // uses current windows user
var myobj = new UpdateAJAXProgress();
var response = (HttpWebResponse)wr.GetResponse();
var reader = new StreamReader(response.GetResponseStream());
JavaScriptSerializer js = new JavaScriptSerializer();
var objText = reader.ReadToEnd();
myobj = (UpdateAJAXProgress)js.Deserialize(objText, typeof(UpdateAJAXProgress));
return Json(myobj);
}
UpdateServerData告诉localhost:55094刷新数据库中的数据.
GetServerUpdateProgress返回进度计数/总计,以便我可以显示数据库刷新的进度栏.
运行UpdateServerData的$.ajax设置为异步工作:true
然后使用setTimeouts,每隔几秒钟运行一次GetServerUpdateProgress,它返回UpdateServerData距完成的距离.
工作应用功能:
不起作用:
因此,在非工作版本中似乎正在发生的事情是,即使ajax正在调用该函数,它也没有运行GetServerUpdateProgress,在UpdateServerData完成之前,它实际上并没有开始处理其中的任何内容.您可以看到ajax同步设置正确,因为在非工作屏幕截图中都显示了加载动画.我在GetServerUpdateProgress的开头放置了一个断点,直到UpdateServerData完成处理后它才触发.
我主要担心的是,可能在webconfig或global.asax中的某些设置是不同的,这就是导致这两个应用程序运行略有不同的原因.有任何想法吗?
以下是一些相关的javascript:
function UpdateData()
{
$("#ChartUpdateProgressWhole").show();
$.ajax({
type: "POST",
async: true,
url: '@(Url.Action("UpdateServerData", "Charts"))',
contentType: "application/json; charset=utf-8",
success: function (data) {
Alert2({
iconfilename: "tick.png",
text: "Database Updated!",
autohide: true,
});
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
},
complete:function (jqXHR, textStatus) {
$("#ChartUpdateProgressWhole").hide();
timerStop = true;
LoadChart();
},
});
if (!timerStop) {
CheckProgress();
}
}
function CheckProgress()
{
if(timerStop) {
CheckProgressAjax();
return;
}
window.setTimeout(CheckProgress, 2000);
CheckProgressAjax();
}
function CheckProgressAjax()
{
$.ajax({
type: "POST",
async: false,
url: '@(Url.Action("GetServerUpdateProgress", "Charts"))',
contentType: "application/json; charset=utf-8",
success: function (data) {
var width = (data.Completed * 100)/data.Total;
$("#ChartUpdateProgressPercent").css("width", width);
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest.status);
alert(XMLHttpRequest.responseText);
}
});
}
解决方法:
这里有点困难,但是ASP.NET实际上将使异步请求排队,并在启用会话状态的情况下按顺序处理它们(无疑避免了处理同步问题).
我的建议是,如果可行的话,一起禁用会话状态,如果不可能的话,可以使用以下属性为每个控制器禁用会话状态:
[SessionState(SessionStateBehavior.Disabled)]
public class SomeController
标签:javascript,c,jquery,asp-net-mvc-3 来源: https://codeday.me/bug/20191207/2087070.html