如何在vuejs中使用signedURL加载从aws s3下载的图像对象?

时间:2018-06-01 18:37:02

标签: javascript amazon-s3 vue.js vuejs2 base64

<div v-for="(data, key) in imgURL" :key="key">
 <img :src= "getLink(data)" />
</div>

其中imgURL包含文件名,它是文件名的集合。

  methods: {
     async getLink(url){
      let response = await PostsService.downloadURL({
        imgURL : url
      })
      //return response.data
      let imgdata = await axios.get(response.data)
      console.log(imgdata.data)
      return imgdata.data
     }
  }

在控制台中,它会打印base64图像

  

数据:图像/ PNG; BASE64,iVBORw0KGgoAAAANSUhEUgAAAwAAAAHkCAIAAAAGqd9kAAAAA3NCSVQICAjb4U / gAAAAGXRFWHRTb2Z0d2FyZQBnbm9tZS1zY3JlZW5zaG907wO / PgAAIABJREFUeJ .....

但是图片没有加载。

我尝试链接从服务器生成但没有用的直接网址,因为我存储了部分文件名并使用它来生成完整的网址。生成的signedURL在上面的代码中是“response.data”。

我使用带有signedURL的fileReader和axios上传图片。

我想知道问题出在哪里?

2 个答案:

答案 0 :(得分:0)

您需要删除异步

如果没有异步,那么它正在工作

 var app = new Vue({
        el: '#app',
        data: {
            message: '',
        },
        methods: {
            getLink() {

                return ""
            }
        }
    })
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

<div id="app">
    <img :src="getLink()" />
</div>

当异步时它不起作用

 var app = new Vue({
        el: '#app',
        data: {
            message: '',
        },
        methods: {
           async getLink() {

                return ""
            }
        }
    })
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

<div id="app">
    <img :src="getLink()" />
</div>

答案 1 :(得分:0)

您不需要使用base64编码数据来显示图像,它很慢。我会说,只需使用签名的网址。我正在做你正在做的事情,但后来发现无需下载图像数据而只需使用签名网址作为图像源。同时生成签名的URL是同步的,这使得处理代码变得容易。

所以不是这个

<div v-for="(data, key) in imgURL" :key="key">
  <img :src= "getLink(data)" />
</div>

这样做

<div v-for="(data, key) in imgURL" :key="key">
  <img :src="data" />  // I am not Vue guy, so use `data` value here
</div>