1

私は言わせて:

最初のリンクをクリックして、[名前を付けて保存] ボックスが表示されたら、[キャンセル] をクリックします。次に、

2 番目のリンクをクリックすると、[名前を付けて保存] ボックスが表示され、[キャンセル] をクリックします。次に、

3 番目のリンクをクリックすると、[名前を付けて保存] ボックスが表示され、[キャンセル] をクリックします。</p>

現時点では、ポップアップ ボックスが表示されず、ビジー状態と同じページが表示されます。

win7 だけの状態。XPでは問題ありません。

私の悪い英語でごめんなさい!インデックス.aspx:

<a href="ShowFile.aspx?fileID=1" >download</a>
<a href="ShowFile.aspx?fileID=2" >download</a>
<a href="ShowFile.aspx?fileID=3">download</a>
<a href="ShowFile.aspx?fileID=4" >download</a>

ShowFile.aspx.cs:

protected void Page_Load(object sender, EventArgs e)
        {

            Page.Response.Clear();
            bool success = ResponseFile(Page.Request, Page.Response, "1.doc", @"d:\1.doc", 1024000);
            if (!success)
                Response.Write("dowload error!");
            Page.Response.End();
        }
        public static bool ResponseFile(HttpRequest _Request, HttpResponse _Response, string _fileName, string _fullPath, long _speed)
        {
            try
            {
                FileStream myFile = new FileStream(_fullPath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
                BinaryReader br = new BinaryReader(myFile);
                try
                {
                    _Response.AddHeader("Accept-Ranges", "bytes");
                    _Response.Buffer = false;
                    long fileLength = myFile.Length;
                    long startBytes = 0;

                    double pack = 10240; //10K bytes
                    //int sleep = 200;   //
                    int sleep = (int)Math.Floor(1000 * pack / _speed) + 1;
                    if (_Request.Headers["Range"] != null)
                    {
                        _Response.StatusCode = 206;
                        string[] range = _Request.Headers["Range"].Split(new char[] { '=', '-' });
                        startBytes = Convert.ToInt64(range[1]);
                    }
                    _Response.AddHeader("Content-Length", (fileLength - startBytes).ToString());
                    if (startBytes != 0)
                    {
                        //Response.AddHeader("Content-Range", string.Format(" bytes {0}-{1}/{2}", startBytes, fileLength-1, fileLength));
                    }
                    _Response.AddHeader("Connection", "Keep-Alive");
                    _Response.ContentType = "application/octet-stream";
                    _Response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(_fileName, System.Text.Encoding.UTF8));

                    br.BaseStream.Seek(startBytes, SeekOrigin.Begin);
                    int maxCount = (int)Math.Floor((fileLength - startBytes) / pack) + 1;

                    for (int i = 0; i < maxCount; i++)
                    {
                        if (_Response.IsClientConnected)
                        {
                            _Response.BinaryWrite(br.ReadBytes(int.Parse(pack.ToString())));
                            Thread.Sleep(sleep);
                        }
                        else
                        {
                            i = maxCount;
                        }
                    }
                }
                catch
                {
                    return false;
                }
                finally
                {
                    br.Close();

                    myFile.Close();
                }
            }
            catch
            {
                return false;
            }
            return true;
        }
4

1 に答える 1

1

通常、ファイルをダウンロードするためのページを作成するときは、ハンドラーを使用するか、少なくともその aspx ページがセッションを無効にする場合は、ハンドラーを使用することをお勧めします。

その理由は、セッションが終了するまでユーザーをロックし、ファイルをダウンロードするときに通常時間がかかるか、停止するとネットワークが閉じていることを理解するまでスタックする可能性があるためです。

したがって、この aspx ページのセッションを無効にすると、問題を解決できます。

相対:
同じセッションを共有している別の Web アプリの処理中に Web アプリがブロックされた
ASP.NET のボトルネックを特定するのに役立つ perfmon カウンター
ASP.Net のセッションを完全に置き換える
Web メソッドを非同期にしようとする

于 2013-07-03T08:10:30.930 に答える