0

長時間実行されている操作のステータスの進行状況を取得しようとしました。FF:)、Opera、IE:? では問題なく動作しますが、Chrome では?! 失敗します: Generic Handler の ProcessRequest に入ることはありません。私が間違っていることを教えてください。

default.aspx:

<%@ Page Title="Home Page" Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true"
CodeBehind="Default.aspx.cs" Inherits="AspNetProgressBar._Default" %>

<asp:Content ID="HeaderContent" runat="server" ContentPlaceHolderID="HeadContent">
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type="text/javascript"></script>
</asp:Content>
<asp:Content ID="BodyContent" runat="server" ContentPlaceHolderID="MainContent">
    <asp:Button runat="server" Text="Run" OnClick="button_Click" OnClientClick="button_start()"  />
...

<script type="text/javascript">
    function button_start() {
        setInterval(function () {
            $.ajax({
                url: 'StatusHandler.ashx',
                data: { statusKeyId: '<%= ViewState["key"] %>' },
                type: 'post',
                dataType: 'json',
                success: function (json) {
                    ... process response
                },
                error: function () {

                }
            });
        }, 1000);
    }
</script>

...

default.aspx.cs

....
protected void button_Click(object sender, EventArgs e)
    {
        System.Threading.Thread.Sleep(2000);
        for (int i = 0; i < 10; ++i)
        {
            System.Threading.Thread.Sleep(500);
            // TODO: update progress status
        }
        // lblStatus.Text = "Done";
    }

StatusHandler.ashx.cs:

public class StatusHandler : IHttpHandler
{

    public void ProcessRequest(HttpContext context)
    {
        context.Response.ContentType = "application/json";

        string statusKeyId = context.Request.Params["statusKeyId"];
        if (statusKeyId != null)
        {
                System.Web.Script.Serialization.JavaScriptSerializer s = new System.Web.Script.Serialization.JavaScriptSerializer(GetStatusInfo(statusKeyId ));
                string output = s.Serialize(info);
                context.Response.Write(output);
                return;
        }
        context.Response.Write("{test: \"empty\"}");
    }
4

1 に答える 1

0

問題は、これが Chrome では機能しないのに、なぜ IE と Firefox で機能するのかということではありません。

ボタンをクリックすると、ブラウザは通常の http リクエストをサーバーに送信して、ページ全体を置き換えます。お気づきのように、JavaScriptが実行されているか、その瞬間にページ上で実行されていないかの動作は未定義であるか、少なくともブラウザごとに異なると思います。

より良い方法は、非同期リクエスト (Ajax) でサーバーを呼び出して、ページがブラウザーでアクティブなままになるようにすることです。次に、長時間実行されているプロセスの準備ができていることを StatusHandler が応答したら、サーバーから結果のページを取得できる URL にブラウザーをリダイレクトできます。

于 2012-10-31T15:41:36.067 に答える