Asp.NET导出Excel文件乱码解决若干方法

来源:转载

在Asp.NET开发过程中经常会将一些列表项目导出为Excel方便用户查看和保存,但是也经常遇到文件名乱码、文件内容乱码等问题。最近我也接到了这样的Bug,现总结了若干个解决办法,供遇到问题的朋友们参考一下。希望以下的某些方法可以解决您的问题。

程序逻辑及问题

前端点击导出Excel之后,从后台数据库中绑定数据到GridView控件,将GridView控件的内容保存到临时文件。最后从临时文件读取数据流并输出到前台。

问题:有些列表导出到Excel之后打开显示乱码。文件名在IE6下显示乱码,在IE8下显示正常。

关注点

除了考虑程序方面的问题之外首先还需要先考虑以下几个方面:

操作系统

这里包括服务器与客户端的操作系统,如果是在中文的环境下建议直接安装中文的操作系统。对于英语或者其它语言的操作系统需要在区域和语言选项里安装东亚字符集,将语言和时区都选择中国。这可以解决英文操作系统下无法显示中文字符的问题。

 

数据库

    跟操作系统一样最好直接安装中文版的数据库,另外对于中文字符的字段类型应该选择运行中文的字段类型。往数据库插入中文字符的时候记得在字符串前面加"N”,如

 

insert into MyTable(name,nickname) values('Gary Zhang',N'地球人'); 

    “有些数据内容显示乱码”是因为在不同数据库下产生的现像,但没有深入去检查数据库的问题,所以就暂时不讨论。  

 

浏览器的支持

不同的浏览器对于文件名的编码也是不一样的,因此在编码时需要注意不同浏览器的支持,或者是否是因为浏览器问题引起乱码。比如常见的浏览器对含有中文字符的文件名称显示乱码。目前这个文件名在IE6乱码的问题还没有解决,即经过UTF-8编码的中文文件名在IE6下直接打开文件名还会显示乱码,而保存而不会有这个问题。在IE8下则都不会有问题。

参考《如何在下载文件名中使用UTF-8编码》中提到的关于不同浏览器对于Content-Description的支持,可以自己试一下。

IE6attachment; filename="<URL编码之后的UTF-8文件名>"FF3attachment; filename="UTF-8文件名"attachment; filename*="utf8''<URL编码之后的UTF-8文件名>"O9attachment; filename="UTF-8文件名"Safari3(Win)貌似不支持?上述方法都不行

 

使用统一的编码方式

  Excel数据文件导出的整个过程可能前期的数据录入数据库->取数据填充GridView等控件或者生成相应的Table表格->转换成stream并输出等过程。在整个过程中尽量使用统一的常用的编码方式比如UTF-8,

[1] [2] 下一页

分享给朋友:
------分隔线----------------------------
您可能感兴趣的文章:
随机阅读: