C# 导出Excel "正在中止线程" 错误

导出Excel相信很多人都用过,但是我却遇到了一个问题 “正在中止线程”

源代码如下:

public static void ExportExcel(string fileName, GridView gvMain)
        {
            //当前对话 
            System.Web.HttpContext curContext = System.Web.HttpContext.Current;
            //IO用于导出并返回excel文件 
            System.IO.StringWriter strWriter = null;
            System.Web.UI.HtmlTextWriter htmlWriter = null;

            if (gvMain.DataSource != null)
            {
                //设置编码和附件格式 
                curContext.Response.Clear();
                curContext.Response.Buffer = true;
                //System.Web.HttpUtility.UrlEncode(FileName, System.Text.Encoding.UTF8)作用是方式中文文件名乱码
                curContext.Response.AddHeader("content-disposition", "attachment;filename=" + System.Web.HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8) + ".xls");
                curContext.Response.ContentType = "application/vnd.ms-excel";
                //解决输出的内容为乱码问题
                curContext.Response.Write("<meta http-equiv=Content-Type content=text/html;charset=UTF-8>");

                //导出Excel文件 
                strWriter = new System.IO.StringWriter();
                htmlWriter = new System.Web.UI.HtmlTextWriter(strWriter);


                //下载到客户端 
                gvMain.RenderControl(htmlWriter);
                curContext.Response.Write(strWriter.ToString());
                
                htmlWriter.Close();
                strWriter.Close();
                curContext.Response.End();
            }
        }

执行了也可以把数据导出来,但是却抛出异常。

症状
如果使用 Response.End、Response.Redirect 或 Server.Transfer 方法,将出现 ThreadAbortException 异常。您可以使用 try-catch 语句捕获此异常。 
 
原因
<!-- Inject Script Filtered --> 
Response.End 方法终止页的执行,并将此执行切换到应用程序的事件管线中的 Application_EndRequest 事件。不执行 Response.End 后面的代码行。

此问题出现在 Response.Redirect 和 Server.Transfer 方法中,因为这两种方法均在内部调用 Response.End。 
 
解决方案
要解决此问题,请使用下列方法之一:  对于 Response.End,调用 HttpContext.Current.ApplicationInstance.CompleteRequest 方法而不是 Response.End 以跳过 Application_EndRequest 事件的代码执行。 
 对于 Response.Redirect,请使用重载 Response.Redirect(String url, bool endResponse),该重载对 endResponse 参数传递 false 以取消对 Response.End 的内部调用。例如: 
  Response.Redirect ("nextpage.aspx", false);            
如果使用此替代方法,将执行 Response.Redirect 后面的代码。 
     对于 Server.Transfer,请改用 Server.Execute 方法。

from:http://blog.csdn.net/zhensoft163/article/details/5995146

原文地址:https://www.cnblogs.com/liuqiyun/p/6897704.html