下载OSS文件如何修改文件名

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

 

    原文作者:快乐的大羊
    原文地址: https://blog.csdn.net/weixin_41838204/article/details/102853894
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞