Скачать файл с помощью angularJS и asp.net mvc
Я новичок в разработке с использованием asp.net MVC. Я пытаюсь загрузить файлы (изображения, PDF..) Вот мой код
в контроллере asp
[HttpPost]
public HttpResponseMessage Download(int id)
{
var db = new TutorialGEDEntities();
Tutorial fileToDownload = db.Tutorials.Find(id);
string name = fileToDownload.filepath;
Debug.WriteLine("filepath " + name);
try
{
if (!string.IsNullOrEmpty(name))
{
//var root = System.Web.HttpContext.Current.Server.MapPath(name);
var filePath = System.Web.HttpContext.Current.Server.MapPath(name); ;
char[] s = new char[name.Length - name.LastIndexOf("\\") - 1];
name.CopyTo(name.LastIndexOf("\\")+1, s, 0, name.Length - name.LastIndexOf("\\")-1);
String fileName = new String(s);
using (MemoryStream ms = new MemoryStream())
{
using (FileStream file = new FileStream(name, FileMode.Open, FileAccess.Read))
{
Debug.WriteLine("file " + file.Length);
byte[] bytes = new byte[file.Length];
file.Read(bytes, 0, (int)file.Length);
ms.Write(bytes, 0, (int)file.Length);
HttpResponseMessage httpResponseMessage = new HttpResponseMessage();
ByteArrayContent content = new ByteArrayContent(bytes.ToArray());
httpResponseMessage.Content = content;
httpResponseMessage.Content.Headers.Add("x-filename", fileName);
httpResponseMessage.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream");
httpResponseMessage.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment");
httpResponseMessage.Content.Headers.ContentDisposition.FileName = fileName;
httpResponseMessage.StatusCode = HttpStatusCode.OK;
return httpResponseMessage;
}
}
}
return null;
}
catch (Exception ex)
{
Debug.WriteLine(ex.Data);
return null;
}
}
и в угловом контроллере
$http({
method: 'POST',
url: 'Download',
data: { 'name': file.filepath },
responseType: 'arraybuffer'
}).success(function (content, status, headers) {
headers = headers();
console.log(content);
console.log(status)
var filename = headers['x-filename'];
var contentType = headers['content-type'];
var linkElement = document.createElement('a');
try {
var blob = new Blob([content], { type: contentType });
console.log(blob);
var url = URL.createObjectURL(blob);
console.log(url)
linkElement.setAttribute('href', url);
linkElement.setAttribute("download", filename);
var clickEvent = new MouseEvent("click", {
"view": window,
"bubbles": true,
"cancelable": false
});
linkElement.dispatchEvent(clickEvent);
} catch (ex) {
console.log(ex);
}
}).error(function (data) {
console.log(data);
});
};
Проблема в том, что я получаю неопределенный и пустой файл. Я отлаживал код, он отлично работает, данные из контроллера asp хорошо структурированы в HttpResponse.
Что я могу сделать, чтобы заставить это работать. Любые другие предложения для загрузки загрузки приветствуются.
Редактировать:
Я изменил функцию загрузки в контроллере asp.net. Я использовал класс HttpResponseMessage. В решении я использовал класс Response.
контроллер asp теперь:
[HttpPost]
public void Download(String name)
{
Debug.WriteLine("filepath " + name);
if (!string.IsNullOrEmpty(name))
{
char[] s = new char[name.Length - name.LastIndexOf("\\") - 1];
name.CopyTo(name.LastIndexOf("\\")+1, s, 0, name.Length - name.LastIndexOf("\\")-1);
String fileName = new String(s);
//var filePath = System.Web.HttpContext.Current.Server.MapPath("~/App_Data/") + fileName;
Response.ContentType = "application/octet-stream";
Response.AppendHeader("Content-Disposition", fileName);
Response.AppendHeader("X-FileName", fileName);
Response.TransmitFile(name);
Response.End();
}
}
1 ответ
$http({
method: 'POST',
url: 'Download',
data: { 'name': file.filepath },
responseType: 'arraybuffer',
transformRequest: angular.identity,
}).
angular.identity
не позволяет Angular делать что-либо с нашими данными (например, сериализацию).