最近在做一个ASP.NET MVC项目,有一个功能是实现生成excel文件并下载。在生成excel文件时,总是会因为路径问题,导致无法正确的写道文件位置。在网上查了给种方法,一直在说用Server.MapPath()
。但是在我的项目中,是没有这个方法。对于我这种小白来说,当然是不知道原因了。
最后在无意间发如何在ASP.Net Core中为Server.MapPath获取绝对路径 的内同,于是就按照这种方法试了一下。结果实现了生成文件写入想要的项目路径下。
现在回想,是不是其他帖子说的Server.MapPath()
是如上述网页自己实现的。
我就是只用了其中一种简单的方法。我是用的代码如下:
private IHostingEnvironment _hostingEnvironmen;
public ClassManageController(IHostingEnvironment environment)
{
_hostingEnvironmen = environment;
}
var testpath = Path.Combine(_hostingEnvironmen.WebRootPath, pathFile);
这样就可以实现将生成的文件保存的想要的路径下了。到这里完成功能的一半了,下来是解决如何在下载文件时可以重命名。本来想在controller里直接实现,但是用return File()
但会的时候不起效果。于是直接专用js去实现了。在[纯js实现文件下载并重命名功能的帮助下,实现了功能。用到的代码如下:
function getBlob(url,cb) {
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true);
xhr.responseType = 'blob';
xhr.onload = function() {
if (xhr.status === 200) {
cb(xhr.response);
}
};
xhr.send();
}
function saveAs(blob, filename) {
if (window.navigator.msSaveOrOpenBlob) {
navigator.msSaveBlob(blob, filename);
} else {
var link = document.createElement('a');
var body = document.querySelector('body');
link.href = window.URL.createObjectURL(blob);
link.download = filename;
link.style.display = 'none';
body.appendChild(link);
link.click();
body.removeChild(link);
window.URL.revokeObjectURL(link.href);
};
}
function download(url, filename) {
getBlob(url, function(blob) {
saveAs(blob, filename);
});
};
使用时只需要调用download(url, filename)
。
只是把大神们给的方法做下记录,以便以后学习使用。