小程序使用sdk对接cos存储桶

官方文档地址:https://cloud.tencent.com/document/product/436/31953

操作步骤

下载cos sdk

安装

复制源码文件中的 cos-wx-sdk-v5.js 到自己小程序代码根目录下任意路径,并用相对路径引用:

小程序域名白名单配置

微信公众平台,选择开发 > 开发设置 > 服务器域名
配置地址: examplebucket-1250000000.cos.ap-guangzhou.myqcloud.com

request合法域名、uploadFile合法域名

配置地址可以找后端或者cos上传成功会返回数据中有接口地址

初始化

javascript 复制代码
const COS = require('../../lib/cos-wx-sdk-v5.min.js')

/** 上传临时素材到cos */
uploadMaterialCos (tempFiles) {
  this.setData({
    isShowModal: false
  })
  console.log("tempFiles", tempFiles)
  const _this = this
  const { cosConfig } = _this.data
  wx.showLoading({
    title: '上传中...',
    mask: true
  })
  // 创建存储通对象
  var cos = new COS({
    SecretId: cosConfig.secretId, // 获取的密钥id
    SecretKey: cosConfig.secretKey // 获取的密钥key
  })
  tempFiles.forEach(item => {
    cos.uploadFile({
      Bucket: cosConfig.bucket, /* 必须 */
      Region: cosConfig.region, /* 存储桶所在地域,必须字段 */
      Key: item.key, /* 必须 */
      FilePath: item.path, /* 必须 */
      FileSize: item.size, /* v1.4.3之前的版本必须,v1.4.3及以后的版本非必须 */
      onProgress: function (progressData) { /* 非必须 */
        console.log(JSON.stringify(progressData))
      },
      onFileFinish: function (err, data, options) { /* 非必须 */
        console.log(options.Key + '上传' + (err ? '失败' : '完成'), data)
        _this.uploadMaterial(data, item)
      }
    }, function (err, data) {
      console.log('err', err || data)
      _this.setData({
        isShowModal: false
      })
    })
  })
},

配置信息获取通过后端api

javascript 复制代码
handleCosCredential () {
  cosCredentialApi({}).then(res => {
    const { code, data } = res
    if (code === 200) {
      this.setData({
        cosConfig: data
      })
    } else {
      wx.showToast(res.message)
    }
  }).catch(err => {
    wx.showToast(err.message)
  })
},

cos参数

上传成功

图片

视频

视频太大,分段上传,取值地址在最外面

相关推荐
百锦再4 小时前
抖音小程序开发全景透视:生态解析、技术架构与商业实践
人工智能·ai·微信小程序·小程序·架构·模型·抖音
低代码布道师8 小时前
互联网医院18:前端进阶——CSS“父相子绝”打造专业级卡片交互
前端·css·低代码·小程序·云开发
说私域9 小时前
开源活动报名AI智能客服AI智能名片预约服务小程序在精神服务中的应用场景研究
人工智能·小程序
计算机毕设指导612 小时前
基于微信小程序的家政服务与互助平台【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
说私域14 小时前
开源悬赏活动报名AI智能名片链动2+1模式商城小程序的应用与价值
人工智能·微信·小程序·开源
计算机毕设指导615 小时前
基于微信小程序的个性化漫画阅读推荐系统【源码文末联系】
java·python·微信小程序·小程序·tomcat·maven·intellij-idea
百锦再15 小时前
开发抖音小程序组件大全概述
人工智能·python·ai·小程序·aigc·notepad++·自然语言
Lucky小黄人1 天前
微信小程序开发常见报错
微信小程序·小程序
初学者52132 天前
微信小程序调用录音没反应,本地开发测试却没问题,operateRecorderfail appid privacy api banned
微信小程序·小程序
微爱帮监所写信寄信2 天前
微爱帮监狱寄信写信小程序信件内容实时保存技术方案
java·服务器·开发语言·前端·小程序