问题:从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('下载错误') })