Vue 前端显示文件流图片

简介

通过前端vue发送用户图片,后端flask进行处理后返回以文件流形式的图片。

前端代码

<template>
    <v-container>  // 注意一个vue文件中只能有一个lable,否则npm run serve 会卡死
        <input class="file" name="file" type="file" accept="image/png,image/gif,image/jpeg" @change="update" />
        <img style="width:180px" :src="img" > 
    </v-container>
</template>

<script>
export default {
 data: () => ({
    img : ""
 }),
methods: {
      update(e){
        let file = e.target.files[0];
        let param = new FormData(); //创建form对象
        param.append('file',file);//通过append向form对象添加数据
        console.log(param.get('file')); //FormData私有类对象,访问不到,可以通过get判断值是否传进去
        this.$axios.post('http://127.0.0.1:5000/upload',param,{headers:{'Content-Type':'application/x-www-form-urlencoded' }}, {responseType:"arraybuffer"}) // RESPONSE-TYPE 要定义成arraybuffer或blob
          .then(res=>{
                this.img = 'data:;base64,' + res.data
          })
          .catch(function (error) {
            console.log(error);
          })
      }
    }
}
</script>

后端代码


from flask import Flask, render_template, request, jsonify,send_file, make_response
from flask_cors import CORS
import os
import json
from io import BytesIO
from PIL import Image
import base64

def return_img_stream(img_local_path):
''' 
将图片文件转码成文件流,便于前端传输
'''
  img_stream = ''
  with open(img_local_path, 'rb') as img_f:  #'rb' 允许打开二进制的图片
    img_stream = img_f.read()
    img_stream = base64.b64encode(img_stream)
  return img_stream 

@app.route('/upload',methods=["POST"])
def upload():
    file_obj = request.files['file']
    if file_obj is None:
        # 表示没有发送文件
        return "未上传文件"
    
    file_path = os.path.join(app.config['UPLOAD_FOLDER'], "1.jpg")
    file_obj.save(file_path)
    resp = return_img_stream(file_path)
    return resp

if __name__ == "__main__":
    app.run()

关键问题

  1. 图像的转码 base64
  with open(img_local_path, 'rb') as img_f:  #'rb' 允许打开二进制的图片
    img_stream = img_f.read()
    img_stream = base64.b64encode(img_stream)
  1. vue接受后端过来的数据
res=>{
                this.img = 'data:;base64,' + res.data
     }
  1. 前端显示图片
<img style="width:180px" :src="img" > 

参考

[1] base64 , blob,url图片的处理方式

  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Vue接口返回的二维码文件是一个二进制数据,在前端中可以通过将文件转换为Base64编码的字符串来进行处理和展示。可以使用Axios等HTTP请求库发送请求获取二维码文件,然后将其转换为Base64编码。 首先,在Vue组件中引入Axios库,并发送GET请求获取二维码文件: ```javascript import axios from 'axios'; axios({ method: 'GET', url: '/api/qrcode', responseType: 'blob' // 设置响应类型为二进制数据 }).then(response => { const blob = response.data; const reader = new FileReader(); reader.readAsDataURL(blob); // 将二进制数据转换为Base64编码 reader.onloadend = () => { const base64Data = reader.result; this.qrcodeImage = base64Data; // 将Base64编码的二维码图片赋给组件的数据属性 }; }); ``` 然后,在Vue模板中使用`img`标签来展示Base64编码的二维码图片: ```html <template> <div> <img :src="qrcodeImage" alt="二维码"> </div> </template> ``` 最后,在Vue组件的数据属性中定义`qrcodeImage`用于存储Base64编码的二维码图片: ```javascript export default { data() { return { qrcodeImage: '' }; } } ``` 这样,通过将二维码文件转换为Base64编码的字符串,我们可以在Vue中展示接口返回的二维码图片。 ### 回答2: Vue 接口返回的二维码文件,可以通过以下步骤进行处理: 首先,在 Vue 组件中发起请求获取二维码文件。可以使用 Axios 这样的库来发送 HTTP 请求,并设置响应类型为二进制。 ```javascript axios({ method: 'GET', url: 'your_api_endpoint', responseType: 'blob' // 设置响应类型为二进制 }).then(response => { // 处理返回的二维码文件 const qrCodeBlob = response.data; // ... }).catch(error => { // 处理请求错误 console.error(error); }); ``` 接下来,对返回的二维码文件进行处理。可以使用 FileSaver.js 这样的库将二进制保存为二维码图片文件。 ```javascript import { saveAs } from 'file-saver'; // 保存二维码文件图片文件 saveAs(qrCodeBlob, 'qrcode.png'); ``` 这样就成功将接口返回的二维码文件保存为本地的图片文件了。 请注意,以上代码中的 `your_api_endpoint` 是你实际的接口地址,需要替换为正确的值。另外,需要在 Vue 项目中安装并导入 Axios 和 FileSaver.js 这两个库。 希望以上回答能对你有所帮助,如果还有其他疑问,请随时追问。 ### 回答3: 当Vue接收到接口返回的二维码文件时,可以通过以下方式进行处理: 1. 接口返回的二维码文件可以是一个二进制,我们可以使用Vue中的axios库来发送请求获取该接口返回的文件数据。 2. 在Vue组件中,通过axios发送请求获取接口返回的二维码文件。可以使用axios的get方法来发送请求,并将接口地址作为参数传递进去。 3. 在获取到文件数据后,可以将其转换成Blob对象,可以使用FileReader对象来进行转换。 4. 使用FileReader的readAsDataURL方法将Blob对象转换为data URL,这样可以在前端页面中直接显示这个二维码图片。 5. 将转换后的data URL赋值给Vue组件中的图片对象的src属性,即可在页面上显示二维码图片。 以上是处理Vue接收到接口返回的二维码文件的一般程,具体的实现可能需要根据实际情况进行调整和完善。这样,我们就可以在Vue中成功处理接口返回的二维码文件,并在页面上显示二维码图片

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值