问题:从OSS下载下来的文件不是文件本身的名字,而是一长串文字(为了保持OSS上面文件名的唯一性,会在OSS上面的名字加上比如日期,时间等,这样下载下来的默认名字就变成了【时间+文件原名了】)
我们可以这样子解决:先把文件以流文件的形式下载下来,然后在用a标签的download属性来给文件重新命名
//将文件以流文件的形式下载下来
handleGetBlob(url) {
// console.log(url)
return new Promise(resolve => {
const xhr = new XMLHttpRequest();
xhr.open("GET", url, true);
xhr.responseType = "blob";
xhr.onload = () => {
if (xhr.status === 200) {
resolve(xhr.response);
}
};
xhr.send();
});
},
//下载文件并重新命名
handleSaveAs(blob, filename) {
if (window.navigator.msSaveOrOpenBlob) {
navigator.msSaveBlob(blob, filename);
} else {
const link = document.createElement("a");
const body = document.querySelector("body");
link.href = window.URL.createObjectURL(blob);
link.download = filename;
// fix Firefox
link.style.display = "none";
body.appendChild(link);
link.click();
body.removeChild(link);
window.URL.revokeObjectURL(link.href);
}
}
最后只需要调用这个方法
this.handleGetBlob("OSS地址").then(blob => {
this.handleSaveAs(blob, "文件名称");
}).catch(err=>{
this.$message.warning('下载错误')
})