Can we use Response.Flush () instead of Response.End()

20,577

Solution 1

The Response.Flush() is send to the browser what is on buffer, but is not stop the processing of the page, so it will continue the execution of the next steps.

What is Response.End() do is to stop the execution steps on the next function call in the asp.net Page Life Cycle. http://msdn.microsoft.com/en-us/library/ms178472.aspx

And that's why it need to throw an exception, to throw out of the loop of the series of call.

One alternative is the Response.Close() but this also is not stop the execution steps and probably you have some other error if you try to send something after the close of the connection with the browser. if you do Response.Close() you need to also do Flush() just before you call it or else browser gets unpredictable data.

you can also read : Redirect to a page with endResponse to true VS CompleteRequest and security thread

Solution 2

Use the condition before download the file Response.IsClientConnected -

if (Response.IsClientConnected)
 {
    Response.Clear();
    Response.ClearContent();
    Response.ClearHeaders();
    Response.ContentType = "Application/pdf";
    Response.AppendHeader("Content-Disposition", "attachment; filename=" + fileName);
    Response.TransmitFile(Server.MapPath(@"yourpath" + fileName));
    Response.Flush();
    Response.Close();
  }

It's working for me well after lot of struggle. I hope it works for you too.

Share:
20,577
user1509
Author by

user1509

Updated on July 15, 2022

Comments

  • user1509
    user1509 almost 2 years

    Response.End() generates ThreadAbortException.

    Using HttpContext.Current.ApplicationInstance.CompleteRequest in place of it doesn't solve the problem.

    So, can we use Response.Flush() instead of Response.End()