0

コード ビハインドでの処理に時間がかかるアプリケーションがあります。javascriptからページを呼び出すことで長い処理を開始しようと考えていましたが、

    function OnCopy(type){
    var xmlhttp;
    if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp = new XMLHttpRequest();
    }
    else {// code for IE6, IE5
        xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    }
    xmlhttp.onreadystatechange=function(){
        if (xmlhttp.readyState==4 && xmlhttp.status==200){
        //window.clearInterval(interval_handler);
        alert('done');
        }
    }
    xmlhttp.open("GET", "<%=Request.Path %>?copy=" + type, true);
    xmlhttp.send();
    interval_handler = window.setInterval(OnCheckStatus, 1000);   
}

この関数の最後の行は、タイマーを開始して、毎秒ステータスをチェックします。

    function OnCheckStatus(){
    var xmlhttp;
    if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp = new XMLHttpRequest();
    }
    else {// code for IE6, IE5
        xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    }
    xmlhttp.onreadystatechange=function(){
        if (xmlhttp.readyState==4 && xmlhttp.status==200){
            //window.clearInterval(interval_handler);
            //var result = eval(xmlhttp.responseText);
            //var pb = document.getElementById('progressbar_' + result[0]);
            //if(pb != null)
            //    pb.innerHTML = result[1] + ' % - ' + result[2];
            debug++;
            var pb = document.getElementById('progressbar_test');
            pb.innerHTML = debug;
        }
    }

    xmlhttp.open("GET", "<%=Request.Path %>?checkstatus=1", true);
    xmlhttp.send();
}

コードビハインドでは、この長時間の処理機能とステータス機能のチェックがあります。

    private void Copy(string type)
    {
        Application["ProgressBar.Type"] = type;

        for (int i = 0; i < 100; i++)
        {
            System.Threading.Thread.Sleep(100);
            Application["ProgressBar.Value"] = i.ToString();
        }

        Application["ProgressBar.Type"] = null;
        Application["ProgressBar.Value"] = null;
    }

    private void CheckStatus()
    {
        Response.Clear();

        string type = (string)Application["ProgressBar.Type"];
        string value = (string)Application["ProgressBar.Value"];

        if (type == null) type = "";
        if (value == null) value = "";

        string response = "['" + type + "','" + value + "','" + DateTime.Now.ToString("HH:mm:ss") + "']";
        Response.Write(response);
        Response.End();
    }

問題は、Copy 関数が終了しないまで、コード ビハインドから CheckStatus 関数に応答がないことです (すべての呼び出しがキューに入れられていると思います)。しかし、終了すると、表示されるデバッグ値は 10 から直接開始されます。 、これら 10 回の呼び出しに対するすべての応答が同時に来るように。ASP.NET がブラウザから一度に 1 つの呼び出しにのみ応答するようなものです。サーバーが同じブラウザーから同時に少なくとも 2 つの呼び出しを処理するという印象を受けました。

これで私を助けてくれませんか?

4

1 に答える 1