web页面导出到Excel乱码解决

引言:
前几天 在做web项目的时候 需要导出页面上的数据 到Excel里面
但有的时候出现乱码(有de时候不出现 很奇怪)
原来的代码是这样的:
        HttpContext.Current.Response.Clear();
        HttpContext.Current.Response.AddHeader("content-disposition",
        "attachment;filename=FileName.xls");
        HttpContext.Current.Response.Charset = "GB2312";
        HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//.Unicode;//.UTF8;//
        HttpContext.Current.Response.ContentType = "xls"; //"application/vnd.xls";
        System.IO.StringWriter stringWrite = new System.IO.StringWriter();
        System.Web.UI.HtmlTextWriter htmlWrite = new HtmlTextWriter(stringWrite);
        mygridview.RenderControl(htw);
        HttpContext.Current.Response.Write(sw.ToString());
        HttpContext.Current.Response.End();


如何解决?

修改为下面的代码 问题就解决了

        HttpContext.Current.Response.ClearContent();
        HttpContext.Current.Response.Write("<meta http-equiv=Content-Type; content=text/html;charset=gb2312>");            
        HttpContext.Current.Response.AddHeader("content-disposition", "attachment; filename=MyExcelFile.xls");
        HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
        HttpContext.Current.Response.ContentType = "application/excel";
        System.IO.StringWriter sw = new System.IO.StringWriter();
        System.Web.UI.HtmlTextWriter htw = new System.Web.UI.HtmlTextWriter(sw);
        mygridview.RenderControl(htw);
        HttpContext.Current.Response.Write(sw.ToString());
        HttpContext.Current.Response.End();

仔细比较一下 就是

       HttpContext.Current.Response.Write("<meta http-equiv=Content-Type; content=text/html;charset=gb2312>"); 
      这句话起的作用 (这句话的作用是声明该网页使用gb2312进行编码)
      原来是 HttpContext.Current.Response.Charset = "GB2312";
      我以为有这句话 就可以  看来不行
      还是 使用 <meta http-equiv=Content-Type; content=text/html;charset=gb2312> 比较保险

posted @   郑文亮  阅读(10927)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示