GridView 导出到 Excel 文件报错解决办法
ASP.NET 2.0中将 GridView 导出到 Excel 文件中
下面代码实现将 GridView 导出到 Excel文件中。
值得注意的是VerifyRenderingInServerForm重载方法:
MSDN上的 VerifyRenderingInServerForm 方法的描述:
必须位于 <form runat=server> 标记中的控件可以在呈现之前调用此方法,以便在控件被置于标记外时显示错误信息。发送回或依赖于注册的脚本块的控件应该在 Control.Render 方法的重写中调用此方法。呈现服务器窗体元素的方式不同的页可以重写此方法以在不同的条件下引发异常。
如果回发或使用客户端脚本的服务器控件没有包含在 HtmlForm 服务器控件 (<form runat="server">) 标记中,它们将无法正常工作。这些控件可以在呈现时调用该方法,以在它们没有包含在 HtmlForm 控件中时提供明确的错误信息。
开发自定义服务器控件时,通常在为任何类型的输入标记重写 Render 方法时调用该方法。这在输入控件调用 GetPostBackEventReference 或发出客户端脚本时尤其重要。复合服务器控件不需要作出此调用。
没有这个方法,程序将报错。
今天写了一个导出数据的代码,将数据导出到Excel和Doc中,方法如下:
protected void export_Click(object sender, EventArgs e)
{
Response.Clear();
Response.Buffer = true;
//Response.Charset = "GB2312";
//设置输出文件类型为excel文件。
Response.ContentType = "application/ms-excel";
Response.AppendHeader("Content-Disposition", "attachment;FileName=boiler.xls");
//经测试如果设置为 以下的编码方式一定要与Web.config页面的顶头上的<?xml version="1.0" encoding="UTF-8"?>中的一致
Response.ContentEncoding = System.Text.Encoding.UTF8;
System.IO.StringWriter oStringWriter = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter oHtmlTextWriter = new System.Web.UI.HtmlTextWriter(oStringWriter);
this.GridView1.RenderControl(oHtmlTextWriter);
Response.Output.Write(oStringWriter.ToString());
Response.Flush();
Response.End();
}
导出到Excel和Doc中:
运行时提示错误:System.Web.HttpException: 类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内。此时增加:
public override void VerifyRenderingInServerForm(Control control)
{
}
如果提示:System.InvalidOperationException: 只能在执行 Render() 的过程中调用 RegisterForEventValidation;哪是gridview的allowpaging属性设置为true则应该在<%@ Page Language="C#" Debug="true" %>中增加EnableEventValidation="false" 属性。
这样就一切OK啦!