C# 导出Excel "正在中止线程" 错误
2011-02-20 12:53
676 查看
导出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 方法。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zhensoft163/archive/2010/11/08/5995146.aspx
源代码如下:
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 方法。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zhensoft163/archive/2010/11/08/5995146.aspx
相关文章推荐
- C# 导出Excel "正在中止线程" 错误
- C# 导出Excel "正在中止线程" 错误
- ASP.NET"正在中止线程"错误原因
- 处理ASP.NET"正在中止线程"错误
- ASP.NET"正在中止线程"错误原因
- ASP.NET"正在中止线程"错误原因
- ASP.NET"正在中止线程"错误原及解决方法
- ASP.NET"正在中止线程"错误原因
- ASP.NET"mscorlib:正在中止线程"错误原因
- ASP.NET "正在中止线程"错误原因
- 用sql2005导出数据到access或excel时,出现" 找不到sourceconnectionoledb"的错误
- 向 Excel 的 FIX: 错误消息,当您试图导出 SQL Server 2005 报告:"索引超出范围"
- jxl导出excel出现“文件错误,可能某些数据格式已丢失"
- 某个工具从以下位置返回了错误代码: "正在执行预生成事件..."
- GridView导出成Excel字符"0"丢失/数字丢失的处理方式
- Oracle&C# 导出多Sheet Excel ,使用Oracle Package (不积跬步,无以至千里)
- 导入EXCEL报错:"外部表不是预期的格式错误"、文件格式和扩展名不匹配,文件可能已损坏或不安全的解决方法
- 某个工具从以下位置返回了错误代码: "正在执行生成后事件
- ct : error PRJ0019: 某个工具从以下位置返回了错误代码: "正在执行生成后事件..
- 在eclipse中导出javadoc报"错误: 编码GBK的不可映射字符"解决办法