vue3+vite前端minio上传失败?

前言

  • 公司让做前端上传,曰:"减小服务器压力",之前都是做的后端上传,前端只需要调用接口就可以,先传到服务器,服务器传给minio云或者腾讯云、阿里云。然后minio返回到服务器,服务器再把东西传给我前端。现在需要让前端直接传到minio云上,跳过服务器这一手,从而减轻服务器的压力,括弧加大前端的压力。

过程

  • 本来以为这种玩意信手拈来,因为之前做过腾讯云前端上传,所有感觉非常简单,结果啪啪打脸。minio云真是太难用了(优点支持分片上传),用的minio包,永远报错(报错原因可能是因为看不起vite),只能使用minio-js这个包,百度找遍了,也没有几个写的完整的vite版的minio上传(基本都是webpack脚手架的 ),拼拼凑凑写出来了minio上传功能,在此记录一下vite版本的minio上传。自定义方法,粘贴可用。备注已经写到位了。希望可以帮到之后用vite做minio上传的兄弟,也为以后的自己方便回顾

vite版上传minio方法

1.先安装minio-js,vite脚手架安装minio包没有用的,直接报错。网上那些改路径的都没有用,我已经试过了

css 复制代码
pnpm i minio-js

2.把下面这段代码拿过去写成upload.js,然后在需要上传的页面直接使用就可以了,传入的值一个是文件流,一个是minio的临时密钥

javascript 复制代码
import { initMinio, putObject } from 'minio-js';
     const changeFile=(event,data)=> {
      console.log(event)
        const file = event.file
        console.log(file)
        let reader = new FileReader()
        reader.readAsArrayBuffer(file)
        reader.onload = function (e) {
          let res = e.target.result
          //初始化
          initMinio({
            endPoint: '192.168.0.239', // minio的ip,直接替换自己的即可
            port: 9100, // 端口号,若地址为类似test.minio.com,就不必写端口号
            useSSL: false, // 是否使用ssl
            accessKey: data.accessKey, // 登录的accessKey
            secretKey: data.secretKey,// 登录的secretKey
            sessionToken:data.sessionToken // 登录的sessionToken
          })
          //上传
          putObject('bigdog', res, "/whatsapp/"+file.name, function (err, data) { //第一个桶名,第二个文件,第三个文件名字,第四个回调函数
            if (err) {
              console.log(err)
            }
            else {
               console.log('上传完成')
               console.log(err,data)
            }
          })
        }
      }
export {changeFile}

总结

希望minio云的minio可以搞一搞对vite友好一点。我苦逼的找了一天的文档和百度,觉得有用的话可以点个关注,这里是前端打工仔幸运是我,代码有需要修改的,可以评论区交流下!

相关推荐
学嵌入式的小杨同学4 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
weixin_425543734 小时前
TRAE CN3.3.25 构建的Electron简易DEMO应用
前端·typescript·electron·vite·nestjs
Mr Xu_5 小时前
【Vue3 + ECharts 实战】正确使用 showLoading、resize 与 dispose 避免内存泄漏
前端·信息可视化·vue·echarts
0思必得05 小时前
[Web自动化] Selenium设置相关执行文件路径
前端·爬虫·python·selenium·自动化
雯0609~6 小时前
hiprint:实现项目部署与打印1-官网提供普通html版本
前端·html
不绝1916 小时前
UGUI——进阶篇
前端
Exquisite.6 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
Stephen_Young7 小时前
32岁程序员猝死:让我想起了我曾经的加班经历,庆幸自己还活着
程序员·工控
2501_944525547 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
2601_949857437 小时前
Flutter for OpenHarmony Web开发助手App实战:快捷键参考
前端·flutter