asp.net MVC 4:如何使用angularJs将文件从控制器返回到视图
本文关键字:文件 控制器 返回 视图 angularJs MVC net 何使用 asp | 更新日期: 2023-09-27 18:08:27
我想从服务器下载一个文件,但我不明白我做错了什么。我一直在寻找如何做到这一点,但行不通。这是我发现的一个例子:
控制器(asp.net MVC):public HttpResponseMessage GetFile(string filename)
{
try
{
if (!string.IsNullOrEmpty(filename))
{
//string filePath = HttpContext.Current.Server.MapPath("~/App_Data/") + fileName;
DirectoryInfo dirInfo = new DirectoryInfo(HostingEnvironment.MapPath("~/Documentos"));
string filePath = dirInfo.FullName + @"'" + filename;
using (MemoryStream ms = new MemoryStream())
{
using (FileStream file = new FileStream(filePath, FileMode.Open, FileAccess.Read))
{
byte[] bytes = new byte[file.Length];
file.Read(bytes, 0, (int)file.Length);
ms.Write(bytes, 0, (int)file.Length);
HttpResponseMessage httpResponseMessage = new HttpResponseMessage();
httpResponseMessage.Content = new ByteArrayContent(bytes.ToArray());
httpResponseMessage.Content.Headers.Add("x-filename", filename);
httpResponseMessage.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream");//application/octet-stream
httpResponseMessage.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment");
httpResponseMessage.Content.Headers.ContentDisposition.FileName = file.Name;
httpResponseMessage.StatusCode = HttpStatusCode.OK;
return httpResponseMessage;
}
}
}
return new HttpResponseMessage(HttpStatusCode.NotFound);
}
catch (Exception)
{
return new HttpResponseMessage(HttpStatusCode.BadRequest);
}
}
angular controller:
$scope.downloadFiles = function () {
var filename = "aae49c8e-c523-4ccc-a7ba-88f405072047&file.pdf";
$http({
method: 'GET',
url: 'serv/Consultas/GetFile',
params: { filename: filename },
responseType: "arraybuffer"
}).success(function (response) {
var file = new Blob([(response)], { type: 'application/pdf' });
var fileURL = URL.createObjectURL(file);
$window.open(fileURL);
}).error(function (data, status) {
console.log("Request failed with status: " + status);
});
}
当我加载文件时,我只是得到文件名不完整的"aae49c8e-c523-4cc -a7ba-88f405072047",不加载文件。谢谢你的帮助。
从服务器流式传输文件:
public FileStreamResult GetFile(string filename)
{
try
{
if (!string.IsNullOrEmpty(filename))
{
//string filePath = HttpContext.Current.Server.MapPath("~/App_Data/") + fileName;
DirectoryInfo dirInfo = new DirectoryInfo(HostingEnvironment.MapPath("~/Documentos"));
string filePath = dirInfo.FullName + @"'" + filename;
FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read);
return File(fs, "application/pdf");
}
return new HttpResponseMessage(HttpStatusCode.NotFound);
}
catch (Exception)
{
return new HttpResponseMessage(HttpStatusCode.BadRequest);
}
}
打开一个带有URL to action方法的新窗口,该方法将流式传输PDF,以便它可以在浏览器中显示:
var fileURL = 'serv/Consultas/GetFile?filename=file.pdf';
$window.open(fileURL);