推广小程序前端代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

138 lines
3.6 KiB

2 months ago
  1. /**
  2. * 阿里云OSS工具类
  3. */
  4. import OSSConfig from "@/utils/oss-upload/oss/OSSConfig.js"
  5. //支持web端
  6. import {
  7. uploadFileToOSS
  8. } from '@/utils/oss-upload/oss/web.js'
  9. import ossConfig from '@/config.js'
  10. /**
  11. * 生成一个随机的Key
  12. */
  13. function storeKey() {
  14. let s = [];
  15. let hexDigits = "0123456789abcdef";
  16. for (let i = 0; i < 36; i++) {
  17. s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
  18. }
  19. s[14] = "4";
  20. s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1);
  21. s[8] = s[13] = s[18] = s[23] = "-";
  22. return s.join("");
  23. }
  24. /**
  25. * 根据当天日期在OSS端生成文件夹
  26. */
  27. function storeFolder() {
  28. const date = new Date();
  29. const formatNumber = n => {
  30. n = n.toString()
  31. return n[1] ? n : '0' + n
  32. }
  33. return [date.getFullYear(), date.getMonth() + 1, date.getDate()].map(formatNumber).join('-')
  34. }
  35. /**
  36. * 阿里云OSS上传文件, 所有具体功能的工具函数均基于此
  37. * 注意, resolve时一定为上传成功, 返回OSS上的Key
  38. * @param filePath 待上传文件的URI
  39. * @param key 存储桶中的目标文件名
  40. * @param folder 存储桶中的目标文件夹
  41. */
  42. export function ossUpload(filePath, key = storeKey(), folder = storeFolder()) {
  43. return new Promise((resolve, reject) => {
  44. if (folder && folder?.length > 0) {
  45. if (folder[0] == "/") folder = folder.slice(1, folder.length)
  46. if (folder[folder.length - 1] != "/") folder += "/"
  47. key = folder + key
  48. }
  49. const filePrefixArr = filePath.split(".")
  50. key += `.${filePrefixArr[filePrefixArr.length - 1]}`
  51. let config = {
  52. url: OSSConfig.host,
  53. name: 'file',
  54. filePath,
  55. formData: {
  56. key,
  57. policy: OSSConfig.policyBase64,
  58. OSSAccessKeyId: OSSConfig.accessid,
  59. success_action_status: '200',
  60. signature: OSSConfig.signature,
  61. },
  62. success(res) {
  63. if (res.errMsg.includes("uploadFile:ok")) {
  64. resolve(ossConfig.aliOss.url + key)
  65. } else {
  66. reject(res)
  67. }
  68. },
  69. fail(err) {
  70. reject(err)
  71. }
  72. }
  73. uni.uploadFile(config)
  74. })
  75. }
  76. /**
  77. * 阿里云OSS上传图片
  78. * @param {compressed, key, folder, success, fail} compressed: 是否压缩 key: 存储桶中的目标文件名 folder: 存储桶中的目标文件夹
  79. */
  80. export function ossUploadImage({
  81. key,
  82. folder,
  83. compressed = true, //是否压缩
  84. success, //成功时的回调
  85. fail //失败时的回调
  86. }) {
  87. const sizeType = [compressed ? 'compressed' : 'original']
  88. uni.chooseImage({
  89. count: 1,
  90. sizeType,
  91. success(res) {
  92. // // #ifdef H5
  93. // return uploadFileToOSS(res.tempFiles[0]).then(success).catch(fail)
  94. // // #endif
  95. ossUpload(res.tempFilePaths[0], key, folder).then(success).catch(fail)
  96. },
  97. fail
  98. })
  99. }
  100. /**
  101. * 阿里云OSS上传视频
  102. * @param { key, folder, sourceType, compressed, maxDuration, camera, success, fail}
  103. * key: 存储桶中的目标文件名 folder: 存储桶中的目标文件夹 其它参数同uni.chooseVideo(mpWeixin)
  104. */
  105. export function ossUploadVideo({
  106. key,
  107. folder,
  108. sourceType = ['album', 'camera'], //album 从相册选视频, camera 使用相机拍摄
  109. compressed = true, //是否压缩所选的视频源文件
  110. maxDuration = 60, //拍摄视频最长拍摄时间, 单位秒。最长支持 60 秒
  111. camera = 'back', //调用相机方向, 'front'、'back', 默认'back'
  112. success, //成功时的回调
  113. fail //失败时的回调
  114. }) {
  115. uni.chooseVideo({
  116. sourceType,
  117. compressed,
  118. maxDuration,
  119. camera,
  120. success(res) {
  121. // // #ifdef H5
  122. // return uploadFileToOSS(res.tempFile).then(success).catch(fail)
  123. // // #endif
  124. ossUpload(res.tempFilePath, key, folder).then(success).catch(fail)
  125. },
  126. fail
  127. })
  128. }
  129. const OSS = {
  130. ossUploadVideo,
  131. ossUploadImage,
  132. ossUpload
  133. }
  134. export default OSS;