Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

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

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()

like image 547
user1509 Avatar asked May 31 '12 07:05

user1509


2 Answers

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

like image 153
Aristos Avatar answered Sep 28 '22 14:09

Aristos


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.

like image 43
Viishnuu Avatar answered Sep 28 '22 14:09

Viishnuu