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

本文涉及的产品
密钥管理服务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) { }
         })
       }
     });
   }
 }

})

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

相关文章
|
7月前
|
弹性计算 前端开发 小程序
微信小程序上传文件至阿里云OSS直传(java后端签名+前端直传)
当前的通用文件上传方式是通过前端上传到服务器,再由服务器转存至对象存储。这种方式在处理小文件时效率尚可,但大文件上传因受限于服务器带宽,速度较慢。例如,一个100MB的文件在5Mbps带宽的阿里云ECS上上传至服务器需160秒。为解决此问题,可以采用后端签名的方式,使微信小程序直接上传文件到阿里云OSS,绕过服务器中转。具体操作包括在JAVA后端引入相关依赖,生成签名,并在微信小程序前端使用这个签名进行文件上传,注意设置正确的请求头和formData参数。这样能提高大文件上传的速度。
1235 1
|
6月前
|
存储 小程序 前端开发
【微信小程序 - 工作实战分享】1.微信小程序发送手机短信验证码(阿里云)
【微信小程序 - 工作实战分享】1.微信小程序发送手机短信验证码(阿里云)
549 0
|
3月前
|
人工智能 小程序 Java
【评测】玩转阿里云《10 分钟构建 AI 客服并应用到网站、钉钉或微信中》
本文介绍了使用阿里云百炼大模型在10分钟内构建AI客服,并应用于网站、钉钉或微信中的体验。作者“JavaDog程序狗”详细描述了从搭建到完成的全过程,包括快速上手、遇到的问题及解决方法、定制化需求以及云产品的整体体验。文档清晰易懂,集成过程顺畅,客服支持响应迅速,定制功能满足特定业务需求,总体体验极佳,适合开发者尝试。
167 5
【评测】玩转阿里云《10 分钟构建 AI 客服并应用到网站、钉钉或微信中》
|
5月前
|
小程序
尝试使用阿里云服务器搭建微信小程序
华北电力大学核工程大一学生,出于对编程的热爱与大创项目需求,涉足微信小程序搭建。初期在实验指导下克服不熟悉编程的困难,但后期发现教程引导不足,尤其是对于代码定位缺乏清晰指引。建议加强网页图像指导,以适应不同编程水平用户,尤其是新手。
尝试使用阿里云服务器搭建微信小程序
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的视频点播系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的视频点播系统附带文章源码部署视频讲解等
113 17
|
6月前
|
JavaScript Java 测试技术
基于ssm+vue.js+uniapp小程序的在线视频点播系统附带文章和源代码部署视频讲解等
基于ssm+vue.js+uniapp小程序的在线视频点播系统附带文章和源代码部署视频讲解等
97 8
|
7月前
|
移动开发 小程序 安全
使用阿里云短信+微信短链接跳转微信小程序
此内容是关于使用阿里云短信带传递参数的微信短链接跳转到微信小程序。首先,需要准备微信开发者工具和一个已认证的小程序。接着,开通云开发并配置云开发权限。然后,配置H5静态网页,包括设置云开发权限和处理不同设备的跳转方式。最后,上传云函数并修改其权限,获取微信短信链接,配置短链接参数,并开通阿里云短信服务以进行测试验证。整个过程涉及到了微信开发者工具、云开发、H5页面配置、云函数的创建和部署以及阿里云短信服务的开通和使用等步骤。
674 0
|
7月前
|
应用服务中间件 API 开发工具
阿里云视频点播功能
阿里云视频点播功能
86 0
|
7月前
|
NoSQL Java 微服务
前后端分离项目知识汇总(阿里云Oss,EasyExcel,视频点播,SpringCloud,Redis,Nuxt)-3
前后端分离项目知识汇总(阿里云Oss,EasyExcel,视频点播,SpringCloud,Redis,Nuxt)
224 1
|
7月前
|
前端开发 NoSQL easyexcel
前后端分离项目知识汇总(阿里云Oss,EasyExcel,视频点播,SpringCloud,Redis,Nuxt)-2
前后端分离项目知识汇总(阿里云Oss,EasyExcel,视频点播,SpringCloud,Redis,Nuxt)
170 0

热门文章

最新文章