How to make sure my created filedownload is UTF-8? (and not UTF-8 without BOM)

后端 未结 3 1383
悲&欢浪女
悲&欢浪女 2021-02-08 15:51

i\'ve made a download function to download messages to a CSV file (code is below). Now when i open it up in notepad or notepad++ i see this:

é NY ø ╬ ║► ░ ê ö

(

相关标签:
3条回答
  • 2021-02-08 16:21

    You might want to try using the UTF8Encoding class. The constructor has a parameter that determines if it should provide the BOM or not. You'll probably have to use the GetBytes-method and write the string as a series of bytes in the response, and not convert it back into a .net string object.

    0 讨论(0)
  • 2021-02-08 16:37

    Zareth's answer helped the OP, but it didn't actually answer the question. Here's the correct solution, from this other post:

    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");
    }
    

    The byte-order mark (while not technically required for UTF8) clues certain programs (e.g. Excel >2007) in to the fact that you're using UTF8. You have to manually include it via the GetPreamble() method.

    0 讨论(0)
  • 2021-02-08 16:43

    You could simplify your code a little:

    public ActionResult DownloadPersonalMessages()
    {
        StringBuilder myCsv = new StringBuilder();
        myCsv.Append(new DownloadService().GetPersonalMessages());
        Response.AddHeader("Content-Disposition", "attachment; filename=PersonalMessages.csv");
        return File(Encoding.UTF8.GetBytes(myCsv.ToString()), "text/csv");
    }
    

    As far as the UTF-8 encoding is concerned I am afraid the problem might be in this GetPersonalMessages method. You might need to return a stream or byte array which you could directly return as file.

    0 讨论(0)
提交回复
热议问题