阿里云点播,微信小程序对接阿里云视频点播

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
视频点播 VOD,流量+存储+转码
简介: 网上也有对于阿里云如何在微信小程序里使用,但是很不全,包括阿里云文档的最佳实践里。话不多说上代码了。upvideo(){ var aliOssParams = util.aliOssParams();//主要是获取上传阿里云的加密策略policy和签名signature;以及上传自己要上传到阿里云的地址,当然还有自己阿里云accessid。

网上也有对于阿里云如何在微信小程序里使用,但是很不全,包括阿里云文档的最佳实践里。
话不多说上代码了。
upvideo(){

     var aliOssParams =  util.aliOssParams();//主要是获取上传阿里云的加密策略policy和签名signature;以及上传自己要上传到阿里云的地址,当然还有自己阿里云accessid。
      //上传视频到阿里云
      var that = this;
      wx.chooseVideo({
         maxDuration: 10,
         success: function (res) {
           var tempFilePath = res.tempFilePath;
           var stringFilePath = String(tempFilePath);
           var indexType = stringFilePath.lastIndexOf('.');
           var type = stringFilePath.substring(indexType);
           var alikey = 'video/'+new Date().getTime() + 
            Math.floor(Math.random() * 1000)+ type ;//随机1000内的数加上时间戳作为你存放在阿里云video目录下名字和类型。
           wx.uploadFile({
             url:aliOssParams.host,
             filePath: tempFilePath,
             name: 'file',
             formData: {
               name: tempFilePath,
               key: alikey,//这个是关键它是定义存放在阿里云那个目录下
               policy:aliOssParams.policy,//上传阿里云的加密策略
               OSSAccessKeyId: aliOssParams.aid,//自己阿里云的aid
               success_action_status: "200",
               signature: aliOssParams.signature,//上传阿里云的签名
             },
             success: function (res) {
              var videoUrl = aliOssParams.host+'/'+alikey;//这就是
         刚上传阿里云后的存放的地址链接,通过它打开你刚上传视频。
              that.videoUrl = videoUrl;
               console.log('that',that,videoUrl);
               wx.showToast({
                 title: "上传成功",
                 icon: 'success',
                 duration: 1000
               })
             },
             fail: function ({ errMsg }) {
               wx.showToast({
                 title: "上传失败",
                 duration: 1000
               })
             },
           })
         }
       })

通过代码大家可以看到最关键的是啥,如何获取加密策略和签名了,当然了,阿里云最佳实践里有demo,但是crypto这个库已经废弃了,它demo给你带过来的crypto,你只能自己去提取了。

 这里是我提为大家提取的crypto函数,直接copy用。

  • View Code
    有了上面的crypto工具函数了,就去看看具体如何生成签名与加密策略吧。

import base64 from "base-64"
import {Crypto} from "./crypto.js"
const util = {

aliOssParams(){
    var aid = "xxxxxxx";//你自己的阿里云的accessid
    var aky="xxxxxxxxxx";//你自己的阿里云的accesskey
    var host = "https://xxxxxxxxx.aliyuncs.com";//你自己的阿里云域名
    var policyText = {
            "expiration": "2022-01-01T12:00:00.000Z",//上传的文件失效日期自己定义
            "conditions": [
            ["content-length-range", 0, 10485760000]//上传的内容大小,自己定义
            ]
    };
    var policy = base64.encode(JSON.stringify(policyText));//生成的加密策略
    var bytes = Crypto.util.HMAC(Crypto.util.SHA1, policy, aky, { asBytes: true }) ;
    var signature = Crypto.util.bytesToBase64(bytes);//生成的签名
    return {
                    policy: policy,
                   signature:signature,
                  aid:aid,
                  host: host
               }
}

}

export {util}
至于如何上传图片,大体如下,请保证以上都已经跑通了,base64记得你上面引到。。

多张图片的上传如此
upMyImg(){
var aliOssParams = util.aliOssParams();
var that = this;
wx.chooseImage({

 count: 9,  //最多可以选择的图片总数
 // sizeType: ['compressed'], // 可以指定是原图还是压缩图,默认二者都有
 sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
 success: function (res) {
   // 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片
   var tempFilePaths = res.tempFilePaths;
   //启动上传等待中...
   wx.showToast({
     title: '正在上传...',
     icon: 'loading',
     mask: true,
     duration: 10000
   })
   var uploadImgCount = 0;

   var tempFilePath;
   var stringFilePath = '';
   var alikey = '' ;
   var type='';

   for (var i = 0, h = tempFilePaths.length; i < h; i++) {
        // stringFilePath= String(tempFilePaths[i]);
        // type = stringFilePath.substring(stringFilePath.lastIndexOf('.'));
        alikey = 'imagees/'+new Date().getTime() + Math.floor(Math.random() * 150)+ '.jpg';
        that.srcs.push(tempFilePaths[i]);
        that.setData({srcs: that.srcs});
     wx.uploadFile({
       url: aliOssParams.host,
       filePath: tempFilePaths[i],//上传图片的路径
       name: 'file',
       formData: {
         key: alikey,
         name: tempFilePaths[i],
         policy:aliOssParams.policy,
         OSSAccessKeyId: aliOssParams.aid,
         success_action_status: "200",
         signature: aliOssParams.signature,
       },
       success: function (res) {
         uploadImgCount++;
         console.log('rrrs',res,tempFilePaths[i]);
         // var data = JSON.parse(res.data);
         //服务器返回格式: { "Catalog": "testFolder", "FileName": "1.jpg", "Url": "https://test.com/1.jpg" }
         // console.log('rrr',data);
         console.log('ddd222',res,aliOssParams.host,alikey);
         // var productInfo = that.data.productInfo;
         // if (productInfo.bannerInfo == null) {
         //   productInfo.bannerInfo = [];
         // }
         // productInfo.bannerInfo.push({
         //   "catalog": data.Catalog,
         //   "fileName": data.FileName,
         //   "url": data.Url
         // });
         // that.setData({
         //   productInfo: productInfo
         // });

         //如果是最后一张,则隐藏等待中
         if (uploadImgCount == tempFilePaths.length) {
             // that.srcs.push(tempFilePaths[i]);
             console.log(that.srcs,3222);
           wx.hideToast();
           wx.showToast({
             title: "上传成功",
             icon: 'success',
             duration: 1000
           })
         }
       },
       fail: function (res) {
         wx.hideToast();
         wx.showModal({
           title: '错误提示',
           content: '上传图片失败',
           showCancel: false,
           success: function (res) { }
         })
       }
     });
   }
 }

})

// 上传图片完
}
都是自己亲测,亲坑。。。解决了你的问题,就随手一赞。。

相关文章
|
5月前
【微信公众平台对接】有关【创建发票卡券模板】调用示例
【微信公众平台对接】有关【创建发票卡券模板】调用示例
86 0
|
5月前
【微信公众平台对接】有关【上传图文消息内的图片获取URL】调用示例
【微信公众平台对接】有关【上传图文消息内的图片获取URL】调用示例
132 0
|
5月前
【微信公众平台对接】有关上传pdf到微信
【微信公众平台对接】有关上传pdf到微信
62 0
|
5月前
|
弹性计算 前端开发 小程序
微信小程序上传文件至阿里云OSS直传(java后端签名+前端直传)
当前的通用文件上传方式是通过前端上传到服务器,再由服务器转存至对象存储。这种方式在处理小文件时效率尚可,但大文件上传因受限于服务器带宽,速度较慢。例如,一个100MB的文件在5Mbps带宽的阿里云ECS上上传至服务器需160秒。为解决此问题,可以采用后端签名的方式,使微信小程序直接上传文件到阿里云OSS,绕过服务器中转。具体操作包括在JAVA后端引入相关依赖,生成签名,并在微信小程序前端使用这个签名进行文件上传,注意设置正确的请求头和formData参数。这样能提高大文件上传的速度。
|
5月前
|
前端开发 开发者
【微信公众号对接】有关签名一直报错,提示invalid signature问题(我的签名和使用微信开发者工具验证返回的签名的是一致的)但还是报错!!!
【微信公众号对接】有关签名一直报错,提示invalid signature问题(我的签名和使用微信开发者工具验证返回的签名的是一致的)但还是报错!!!
172 0
|
4月前
|
存储 小程序 前端开发
【微信小程序 - 工作实战分享】1.微信小程序发送手机短信验证码(阿里云)
【微信小程序 - 工作实战分享】1.微信小程序发送手机短信验证码(阿里云)
314 0
|
28天前
|
人工智能 小程序 Java
【评测】玩转阿里云《10 分钟构建 AI 客服并应用到网站、钉钉或微信中》
本文介绍了使用阿里云百炼大模型在10分钟内构建AI客服,并应用于网站、钉钉或微信中的体验。作者“JavaDog程序狗”详细描述了从搭建到完成的全过程,包括快速上手、遇到的问题及解决方法、定制化需求以及云产品的整体体验。文档清晰易懂,集成过程顺畅,客服支持响应迅速,定制功能满足特定业务需求,总体体验极佳,适合开发者尝试。
114 5
【评测】玩转阿里云《10 分钟构建 AI 客服并应用到网站、钉钉或微信中》
|
2月前
|
人工智能 自然语言处理 Serverless
阿里云百炼应用实践系列-让微信公众号成为智能客服
本文主要介绍如何基于百炼平台快速在10分钟让您的微信公众号(订阅号)变成 AI 智能客服。我们基于百炼平台的能力,以官方帮助文档为参考,让您的微信公众号(订阅号)成 为AI 智能客服,以便全天候(7x24)回应客户咨询,提升用户体验,介绍了相关技术方案和主要代码,供开发者参考。
阿里云百炼应用实践系列-让微信公众号成为智能客服
|
3月前
|
小程序
尝试使用阿里云服务器搭建微信小程序
华北电力大学核工程大一学生,出于对编程的热爱与大创项目需求,涉足微信小程序搭建。初期在实验指导下克服不熟悉编程的困难,但后期发现教程引导不足,尤其是对于代码定位缺乏清晰指引。建议加强网页图像指导,以适应不同编程水平用户,尤其是新手。
尝试使用阿里云服务器搭建微信小程序
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的视频点播系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的视频点播系统附带文章源码部署视频讲解等
77 17
下一篇
无影云桌面