[前端] Vue中通过minio上传文件的详细步骤

1962 0
王子 2022-10-21 15:36:47 | 显示全部楼层 |阅读模式
目录

    1、minio的安装2、minio.js文件
      2.1连接minio2.2通过stream流上传2.3通过带预签名的url上传(最好是minio设置了链接永久访问)2.4删除对象补充:base64转blob
    3、获取时间方法4、minio设置链接永久访问(客户端)5、解决跨域问题6、存储大小限制问题7、minio官方文档8、minio设置链接永久访问(其他方法)总结

在Vue中minio上传文件(stream流和链接)

1、minio的安装

直接使用npm或者cnpm下载即可
  1. npm i minio --save
  2. //或者
  3. cnpm i minio --save
复制代码
2、minio.js文件

封装了连接minio、文件上传,文件删除等方法
注:此文件中的url都是在minio设置了永久链接的基础上

2.1连接minio
  1. const minioClient = new Minio.Client({
  2.   endPoint: 'xxx.xxx.x.xxx', // 地址
  3.   port: xx, // 端口号,若地址为类似test.minio.com,就不必写端口号
  4.   useSSL: false, // 是否使用ssl
  5.   accessKey: '', // 登录的accessKey
  6.   secretKey: '' // secretKey
  7. });
复制代码
2.2通过stream流上传
  1. const stream = require('stream')
  2. const Minio = require('minio')
  3. import {
  4.   getNowTime
  5. } from "@common/publicmethods"
  6. /**
  7. *
  8. * @export 上传文件(stream流方法)
  9. * @param {*} backetName String 存储桶名字
  10. * @param {*} fileObj Object 文件对象
  11. * @param {*} path String 文件存储路径
  12. * @param {*} vm Object 调用该方法的页面的this
  13. * @return {*} null
  14. */
  15. export function uploadMinIo(backetName,fileObj, path, vm) {
  16.   if (
  17.     fileObj
  18.   ) {
  19.     let file = fileObj;
  20.     console.log("file", file);
  21.     //判断是否选择了文件
  22.     if (file == undefined) {
  23.       //未选择
  24.     } else {
  25.       //选择
  26.       // 获取文件类型及大小
  27.       // 给文件名加上当前时间
  28.       const fileName = getNowTime("time") + file.name;
  29.       const fileDate = getNowTime("fileDate") // 生成以日为分类的文件夹
  30.       const mineType = file.type;
  31.       const fileSize = file.size;
  32.       console.log("fileName", fileName);
  33.       //参数
  34.       let metadata = {
  35.         "content-type": mineType,
  36.         "content-length": fileSize,
  37.       };
  38.       //判断储存桶是否存在
  39.       minioClient.bucketExists(backetName, function (err) {
  40.         console.log("判断储存桶是否存在");
  41.         if (err) {
  42.           if (err.code == "NoSuchBucket")
  43.             return console.log("bucket does not exist.");
  44.           return console.log(err);
  45.         }
  46.         //准备上传
  47.         let reader = new FileReader();
  48.         console.log(reader);
  49.         reader.readAsDataURL(file);
  50.         reader.onloadend = function (e) {
  51.           //读取完成触发,无论成功或失败
  52.           console.log("ee", e);
  53.           const dataurl = e.target.result;
  54.           //base64转blob
  55.           const blob = toBlob(dataurl);
  56.           //blob转arrayBuffer
  57.           let reader2 = new FileReader();
  58.           reader2.readAsArrayBuffer(blob);
  59.           reader2.onload = function (ex) {
  60.             //定义流
  61.             let bufferStream = new stream.PassThrough();
  62.             //将buffer写入
  63.             bufferStream.end(Buffer.from(ex.target.result));
  64.             //上传
  65.             minioClient.putObject(
  66.               backetName,
  67.               `${path}/${fileDate}/${fileName}`,
  68.               bufferStream,
  69.               fileSize,
  70.               metadata,
  71.               function (err, etag) {
  72.                 // console.log("dddddd");
  73.                 if (err == null) { // 为空则代表上传成功
  74.                   let res = {
  75.                     path: `http://192.168.0.226:30014/${backetName}/${path}/${fileDate}/${fileName}`,
  76.                     result: 1,
  77.                   };
  78.                   // 成功生成url后调用
  79.                   // 调用传进来的this的的方法,然后通过该方法把成功事件发送出去
  80.                   vm.handleAvatarSuccess(res, vm.filedname);
  81.                   vm.fileName = fileName;
  82.                   vm.$message({
  83.                     message: "上传成功!",
  84.                     type: "success",
  85.                   });
  86.                   // 由于minio设置了永久链接,该生成临时url的方法就不再使用
  87.                   // minioClient.presignedGetObject(
  88.                   //   "medialibrary",
  89.                   //   `archive${a}${fileName}`,
  90.                   //   24 * 60 * 60,
  91.                   //   function (err, presignedUrl) {
  92.                   //     if (err) return console.log(err);
  93.                   //     let res = {
  94.                   //       path: presignedUrl,
  95.                   //       result: 1,
  96.                   //     };
  97.                   //     // 成功生成url后调用
  98.                   //     vm.handleAvatarSuccess(res, vm.filedname);
  99.                   //     vm.fileName = fileName;
  100.                   //     vm.$message({
  101.                   //       message: "上传成功!",
  102.                   //       type: "success",
  103.                   //     });
  104.                   //     console.log("链接:",presignedUrl);
  105.                   //   }
  106.                   // );
  107.                 }
  108.               }
  109.             );
  110.           };
  111.         };
  112.       });
  113.     }
  114.   } else {
  115.     this.$message({
  116.       message: "文件类型错误!",
  117.       type: "error",
  118.     });
  119.   }
  120. }
复制代码
2.3通过带预签名的url上传(最好是minio设置了链接永久访问)

1.先拿到预签名链接
2.再通过预签名上传文件
  1. // 两个参数,存储桶的名字,要上传文件的名字。例如test.txt
  2. /**
  3. *
  4. * @export 获取上传链接(url方法)获取上传的url;会生成一个带预签名的链接
  5. * @param {*} bucket String 存储桶的名字
  6. * @param {*} totalFolderName String 总文件夹名字 例如:imagelibrary
  7. * @param {*} fileName String 文件名字
  8. * @return {*} Promise
  9. */
  10. export function getUploadUrl(bucket, totalFolderName,fileName) {
  11.   let defaultPath = getNowTime("fileDate"); // 添加默认的以日为分类的文件夹
  12.   return minioClient.presignedPutObject(bucket, `${totalFolderName}/${defaultPath}/${fileName}`)
  13. }
  14. // 通过url上传
  15. /**
  16. *
  17. * @export 上传文件(url方法)通过获取带预签名的链接上传
  18. * @param {*} url String 预签名链接
  19. * @param {*} data Object 文件对象
  20. * @return {*} Promise
  21. */
  22. export function uploadByUrl(url, data) {
  23.   return fetch(url, {
  24.     mode: "cors", // 解决跨域
  25.     headers: {
  26.       Accept: "application/json,text/plain,/",
  27.     },
  28.     method: "PUT",
  29.     body: data,
  30.   });
  31. }
复制代码
2.4删除对象
  1. /**
  2. * @export 从存储桶中删除一个对象
  3. * @param {*} bucketName 存储桶的名字
  4. * @param {*} objectPathAndName 要删除对象的路径(注意:要写对路径,紧跟存储桶后面的路径)
  5. * @description
  6. * @author
  7. * @version V1.0.0
  8. * @return {*} Promise
  9. */
  10. export function removeObject(bucketName,objectPathAndName){
  11.   return minioClient.removeObject(bucketName, objectPathAndName)
  12. }
复制代码
补充:base64转blob
  1. /**
  2. *
  3. * @export base64转blob
  4. * @param {*} base64Data Object base64数据
  5. * @return {*} blob
  6. */
  7. //base64转blob
  8. export function toBlob(base64Data) {
  9.   let byteString = base64Data
  10.   if (base64Data.split(',')[0].indexOf('base64') >= 0) {
  11.     byteString = window.atob(base64Data.split(',')[1]) // base64 解码
  12.   } else {
  13.     byteString = unescape(base64Data.split(',')[1])
  14.   }
  15.   // 获取文件类型
  16.   let mimeString = base64Data.split(';')[0].split(":")[1] // mime类型
  17.   // ArrayBuffer 对象用来表示通用的、固定长度的原始二进制数据缓冲区
  18.   // let arrayBuffer = new ArrayBuffer(byteString.length) // 创建缓冲数组
  19.   // let uintArr = new Uint8Array(arrayBuffer) // 创建视图
  20.   let uintArr = new Uint8Array(byteString.length) // 创建视图
  21.   for (let i = 0; i < byteString.length; i++) {
  22.     uintArr[i] = byteString.charCodeAt(i)
  23.   }
  24.   // 生成blob
  25.   const blob = new Blob([uintArr], {
  26.     type: mimeString
  27.   })
  28.   // 使用 Blob 创建一个指向类型化数组的URL, URL.createObjectURL是new Blob文件的方法,可以生成一个普通的url,可以直接使用,比如用在img.src上
  29.   return blob
  30. }
复制代码
3、获取时间方法

publicmethods.js
  1. /**
  2. *
  3. *
  4. * @export 获取当前时间并格式化
  5. * @param {*} isDate Boolean 为真返回时分秒; 为"time"返回不带连接符的时分秒;为"fileDate"返回文件夹日期
  6. * @return {*} yyyy-MM-dd hh:mm:ss
  7. */
  8. export function getNowTime(isDate = false) {
  9.     var now = new Date();
  10.     var year = now.getFullYear(); //得到年份
  11.     var month = now.getMonth(); //得到月份
  12.     var date = now.getDate(); //得到日期
  13.     var hh = now.getHours();
  14.     var mm = now.getMinutes();
  15.     var ss = now.getSeconds();
  16.     var hour = " " + hh + ":" + mm + ":" + ss + ""; //默认时分秒 如果传给后台的格式为年月日时分秒,就需要加这个,如若不需要,此行可忽略
  17.     var hours = hh + '' + mm + '' + ss + "-";
  18.     month = month + 1;
  19.     month = month.toString().padStart(2, "0");
  20.     date = date.toString().padStart(2, "0");
  21.     var defaultDate = `${year}-${month}-${date}${hour}`;
  22.     if (isDate) {
  23.         var defaultDate = `${year}-${month}-${date}`;
  24.     }
  25.     if (isDate == 'time') { // 返回给文件前添加的时间
  26.         var defaultDate = `${year}${month}${date}${hours}`;
  27.     }
  28.     if (isDate == 'fileDate') { // 返回默认创建文件夹的时间
  29.         var defaultDate = `${year}${month}${date}`;
  30.     }
  31.     return defaultDate;
  32. }
复制代码
4、minio设置链接永久访问(客户端)

注意: 在设置永久访问后,地址上会有默认的路径:"/minio",需要把它去掉即可正常访问



5、解决跨域问题

修改如下文件中的配置

  1. ingress:
  2.   enabled: true
  3.   labels: {}
  4.     # node-role.kubernetes.io/ingress: platform
  5.   annotations:
  6.     kubernetes.io/ingress.class: nginx
  7.     # kubernetes.io/tls-acme: "true"
  8.     # kubernetes.io/ingress.allow-http: "false"
  9.     # kubernetes.io/ingress.global-static-ip-name: ""
  10.     # nginx.ingress.kubernetes.io/secure-backends: "true"
  11.     # nginx.ingress.kubernetes.io/backend-protocol: "HTTPS"
  12.     # nginx.ingress.kubernetes.io/whitelist-source-range: 0.0.0.0/0
  13.     nginx.ingress.kubernetes.io/cors-allow-headers: DNT,web-token,app-token,Authorization,Accept,Origin,Keep-Alive,User-Agent,X-Mx-ReqToken,X-Data-Type,X-Auth-Token,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,token,Cookie,x-amz-content-sha256,x-amz-date
  14.     nginx.ingress.kubernetes.io/cors-allow-methods: PUT, GET, POST, OPTIONS, DELETE
  15.     nginx.ingress.kubernetes.io/cors-allow-origin: '*'
  16.     nginx.ingress.kubernetes.io/enable-cors: 'true'
复制代码
6、存储大小限制问题

加上下面一行就可以了



7、minio官方文档

官方链接

8、minio设置链接永久访问(其他方法)

minio永久访问

总结

到此这篇关于Vue中通过minio上传文件的文章就介绍到这了,更多相关Vue minio上传文件内容请搜索中国红客联盟以前的文章或继续浏览下面的相关文章希望大家以后多多支持中国红客联盟!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

中国红客联盟公众号

联系站长QQ:5520533

admin@chnhonker.com
Copyright © 2001-2025 Discuz Team. Powered by Discuz! X3.5 ( 粤ICP备13060014号 )|天天打卡 本站已运行