我在我的asp.net mvc 2应用程序在C#中的UTF8编码有问题。我试图让用户从一个字符串下载一个简单的文本文件。我试图得到字节数组与下面这行:
var x = Encoding.UTF8.GetBytes(csvString);
但是当我返回它下载使用:
return File(x,…,…);
我得到一个没有BOM的文件,所以我没有正确显示克罗地亚字符。这是因为我的字节数组在编码后不包括BOM。我三次手动插入这些字节,然后它显示正确,但这不是最好的方法做到。
我也尝试创建UTF8Encoding类实例,并传递一个布尔值(true)到其构造函数以包括BOM,但它也不工作。
任何人都有解决方案?谢谢!
解决方法
尝试这样:
public ActionResult Download() { var data = Encoding.UTF8.GetBytes("some data"); var result = Encoding.UTF8.GetPreamble().Concat(data).ToArray(); return File(result,"application/csv","foo.csv"); }
原因是,采用布尔参数的UTF8Encoding构造函数不会执行您期望的操作:
byte[] bytes = new UTF8Encoding(true).GetBytes("a");
结果数组将包含值为97的单个字节。没有BOM,因为UTF8不需要BOM。