最近在做一個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)
。
只是把大神們給的方法做下記錄,以便以后學習使用。