Vue+Flask中上传图片并在后端保存

文章介绍了在本地开发环境中,前端通过HTMLinput标签选择图片,使用FormData进行文件上传,并通过Ajax发送到后端。后端则从request.files获取文件并保存到服务器。前端尝试使用FileReader读取文件为DataURL来预览图片,但遇到了问题。文章提出了两个疑问:1)前端为何无法展示图片;2)为何不能将DataURL赋值给img的src属性。
摘要由CSDN通过智能技术生成

 本地调试,前后端在一台机器上

前端

首先通过input标签获取文件

accept="image/*"指定只能上传图片

<input type="file" accept="image/*" @change="sendimg">

然后在methods中

新建FormData()对象,以key-value的形式传入要发送的数据

methods:{
    sendimg(e){
      //获取文件
      this.file = e.target.files[0]
   
      //发送图片
      let formData = new FormData()
      formData.append('file',this.file)
      console.log("发送图片")
      this.$ajax.post('/upload',formData).then(rsp=>{
        console.log(rsp)
      })
    }
}

为什么上传的图片在e.target中呢?为什么呢:D

后端

直接从request.files中找到FormData设置的key

利用f.save()保存到服务器本地

@app.route("/upload",methods=['POST'])
def upload():
    print("接收中")
    f = request.files['file']
    if f:
        print("成功接收")
        save_path = os.path.join(os.path.abspath(os.path.dirname(__file__)),'upload',f.filename)
        f.save(save_path)
       # 返回图片的预览地址
        return jsonify({'imgurl':save_path,'code':200})

最后返回保存的文件地址,方便前端展示图片(Q1:为什么我展示不出来,是不能用绝对路径吗:(

Q2:我使用FileReader生成DataURL,却无法赋值给img的src属性,为什莫?

 <img v-if="imgurl" :src="imgurl">



data() {
    return {
 
      file: '',
      imgurl:"",
    },

methods:{
   sendimg(e){
      //获取文件
      this.file = e.target.files[0]

      //预览图片
      var reader = new FileReader();
      
      reader.onload=function(){
         this.imgurl = reader.result;
         console.log(this.imgurl)
       }
      reader.readAsDataURL(this.file);


      //发送图片
      let formData = new FormData()
      formData.append('file',this.file)
      console.log("发送图片")
      this.$ajax.post('/upload',formData).then(rsp=>{
        console.log(rsp)
      })
    }

好的,下面是一个基于Vue和Element UI的文件上传组件案例: 1. 首先,在Vue组件引入Element UI的上传组件: ```html <template> <div> <el-upload class="upload-demo" :action="uploadUrl" :on-success="handleUploadSuccess" :before-upload="beforeUpload" :show-file-list="false" :headers="headers"> <el-button size="small" type="primary">点击上传</el-button> </el-upload> </div> </template> <script> export default { data() { return { uploadUrl: 'your_upload_url', // 上传文件的后端接口地址 headers: { // 可以在这里设置请求头,如认证token等 } } }, methods: { beforeUpload(file) { // 在上传之前的操作,可以在这里对文件进行限制,如大小、格式等 return true }, handleUploadSuccess(response, file, fileList) { // 上传成功的回调函数,可以在这里对上传成功后的结果进行处理 } } } </script> ``` 2. 在后端编写接口来接受上传的文件,并进行处理: ```python from flask import Flask, request app = Flask(__name__) @app.route('/upload', methods=['POST']) def upload(): file = request.files['file'] # 获取上传的文件对象 file.save('path/to/save/file') # 将文件保存到指定路径 # 在这里可以进行对上传文件的操作,如读取文件内容等 return 'Upload success' if __name__ == '__main__': app.run() ``` 需要注意的是,上传文件的后端接口需要支持文件上传,可以使用Flask的`Flask-Uploads`或`werkzeug`库来实现。同时,在前端上传文件时需要将文件数据以FormData的形式发送到后端,可以使用Axios或Fetch等库来实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值