ASP.NET之导出Excel——无乱码现象
2023-09-14 09:16:29 时间
GridView控件导出Excel的方式及部分错误解决方案
ASP.net导出的Excel并非真正的Excel
- 导出Excel核心代码
//清除缓冲中的所有内容输出
Response.Clear();
//设置输入流的http字符集
Response.Charset = "GB2312"; //中文字符编码
//设置是否缓冲输出并在处理完整个响应之后发送它
Response.Buffer = true;
//将http的头添加到输出流 设置导出后文件名称
Response.AppendHeader("Content-Disposition", "attachment;filename=用户信息.xls");
//设置输出内容的编码格式
Response.ContentEncoding = System.Text.UTF8Encoding.GetEncoding("GB2312");
//设置输出流的http mime类型
Response.ContentType = "application/ms-excel";
//实例化一个用于写入字符串的对象
System.IO.StringWriter sw = new System.IO.StringWriter();
//将文本写入到asp.net服务器控件输出流
System.Web.UI.HtmlTextWriter htw = new System.Web.UI.HtmlTextWriter(sw);
//隐藏选择列,不导出选择列,列索引从0开始
gvUserInfo.Columns[0].Visible = false;
//导出前先取消分页,以便能将所有数据导出。
gvUserInfo.AllowPaging = false;
//将GridView控件内容输出至服务器
gvUserInfo.RenderControl(htw);
//以异步的形式将字符串写入到文本字符或者流
Response.Output.Write(sw.ToString());
//向客户端发送当前缓冲的输出
Response.Flush();
//停止输出
Response.End();
/// <summary>
/// 必须重写VerifyRenderingInServerForm方法
/// </summary>
/// <param name="control"></param>
public override void VerifyRenderingInServerForm(Control control)
{
}
错误1:没有重写VerifyRenderingInServerForm()
方法
解决方案:重写VerifyRenderingInServerForm()
方法
错误2:导出Excel时只能在执行 Render() 的过程中调用 RegisterForEventValidation
解决方案:
在此<%@ Page Language="C#" AutoEventWireup="true" Inherits="UI.AdminMain" %>
代码段中加入EnableEventValidation = "false" CodeFile="AdminMain.aspx.cs"
CodeFile=“AdminMain.aspx.cs” 引号中填写当前页面后台代码的文件名称(全称)
相关文章
- 【原创】.NET读写Excel工具Spire.Xls使用(5)重量级的Excel图表功能
- 【原创】.NET读写Excel工具Spire.Xls使用(2)Excel文件的控制
- 使用 Visual Studio 部署 .NET Core 应用 ——.Net Core 部署到Ubuntu 16.04
- C#.Net实体代码生成工具(EntitysCodeGenerate)的使用及.NET中的ORM实现
- ASP.NET datable导出excel
- .net自定义控件
- excel怎么设置密码保护?Excel文件添加密码保护教程
- Asp.net(C#) windows 服务{用于实现计划任务,事件监控等}
- C#.net word excel powerpoint (ppt) 转换成 pdf 文件
- ASP.NET Core 6框架揭秘实例演示[09]:将配置绑定为对象
- .NET Framework 源码
- 常见掌握类库与工具体系图 艾提拉总结 Atitit 文档资料处理重要类库与工具体系树 Configuration yml xml jsoup Net apache commons net
- Atitit ..Net Framework sdk 3.0 3.5 4.04.5 4.6 4.7 .net core版本新特性 v2 s22 1. 新特性来源于 down ms 官方网站1
- Atitit.excel导出 功能解决方案 php java C#.net版总集合.doc
- Atitit.导出excel报表的设计与实现java .net php 总
- 你的NET程序需要保护吗?Agile.net 6.6.X 注入式Crack
- .NET:GrapeCity Documents for Excel (GcExcel)
- (转) 选择 NET Framework 3.5 SP1 系统必备,ClickOnce 发布提示缺少文件的解决方案
- Net Core 微服务 - 如何在docker容器里运行一个简单的.net core web api 服务
- JAVA操作Excel表格:方法二:POI的使用②:Excel实战之POI解析读取excel文件(低版本)