我正在尝试发送一个 9MB 的.xls
文件作为来自 web api 控制器方法的响应。用户将单击页面上的按钮,这将通过浏览器触发下载。
这是我到目前为止所得到的,但它不起作用,但它也不会引发任何异常。
[AcceptVerbs("GET")]
public HttpResponseMessage ExportXls()
{
try
{
byte[] excelData = m_toolsService.ExportToExcelFile();
HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK);
var stream = new MemoryStream(excelData);
result.Content = new StreamContent(stream);
result.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream");
result.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment")
{
FileName = "Data.xls"
};
return result;
}
catch (Exception ex)
{
m_logger.ErrorException("Exception exporting as excel file: ", ex);
return Request.CreateResponse(HttpStatusCode.InternalServerError);
}
}
这是通过界面中的按钮单击进行的咖啡脚本/javascript jquery ajax 调用。
$.ajax(
url: route
dataType: 'json'
type: 'GET'
success: successCallback
error: errorCallback
)
现在我考虑一下,也许 dataType 是错误的,不应该是 json ......