Угловой скачать CSV-файл с Web Api 2
Я пытаюсь скачать CSV-файл, используя веб-API 2 и угловой JS.
Это код моего контроллера
public IHttpActionResult ExportCsvData()
{
var stream = new FileStream("Testcsv.csv", FileMode.Open, FileAccess.Read);
var response = new HttpResponseMessage(HttpStatusCode.OK);
response.Content = new StreamContent(stream);
response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream");
response.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment")
{
FileName = "Testcsv.csv"
};
return Ok(response);
}
Это мой угловой код,
var filename = 'testcsv.csv';
var contentType = 'text/csv;charset=utf-8';
var blob = new Blob([data], { type: contentType });
if (navigator.msSaveBlob) {
navigator.msSaveBlob(blob, filename);
}
Я использую IE 11, но когда я открываю файл в Excel, это выглядит так,
{ "version": {
"major": 1
"minor": 1
"build": -1
"revision": -1
"majorRevision": -1
"minorRevision": -1 } "content": {
"headers": [
{
"key": "Content-Type"
"value": [
"application/octet-stream"
]
}
{
"key": "Content-Disposition"
"value": [
"attachment; filename=testcsv.csv"
]
}
]
Что я делаю неправильно?
Спасибо!
1 ответ
Решение
Вам необходимо вернуть ответное сообщение. Ok()
будет сериализовать HttpResponseMessage как есть.
public IHttpActionResult ExportCsvData()
{
var stream = new FileStream("Testcsv.csv", FileMode.Open, FileAccess.Read);
var response = new HttpResponseMessage(HttpStatusCode.OK);
response.Content = new StreamContent(stream);
response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream");
response.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment")
{
FileName = "Testcsv.csv"
};
return ResponseMessage(response);
}