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

简介: 网上也有对于阿里云如何在微信小程序里使用,但是很不全,包括阿里云文档的最佳实践里。话不多说上代码了。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) { }
         })
       }
     });
   }
 }

})

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

相关文章
|
8天前
|
缓存 小程序 前端开发
商城/点餐/家政类小程序源码合集_微信抖音小程序源码开发从入门到精通实战
本文系统讲解如何利用现有源码快速开发商城、点餐、家政类微信/抖音小程序,涵盖环境搭建、核心功能实现、多平台部署与优化,提供完整技术方案。实战导向,助力开发者高效入门与落地。
|
10天前
|
存储 小程序 Java
热门小程序源码合集:微信抖音小程序源码支持PHP/Java/uni-app完整项目实践指南
小程序已成为企业获客与开发者创业的重要载体。本文详解PHP、Java、uni-app三大技术栈在电商、工具、服务类小程序中的源码应用,提供从开发到部署的全流程指南,并分享选型避坑与商业化落地策略,助力开发者高效构建稳定可扩展项目。
|
4月前
|
JSON 监控 小程序
微信百度字节小程序包过大解决方案(实战经验总结)-优雅草卓伊凡|果果|小无
微信百度字节小程序包过大解决方案(实战经验总结)-优雅草卓伊凡|果果|小无
282 14
微信百度字节小程序包过大解决方案(实战经验总结)-优雅草卓伊凡|果果|小无
|
11月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
2521 7
|
6月前
|
存储 移动开发 小程序
校园圈子系统小程序(圈子论坛、私信聊天、资料共享、二手交易、兼职,跑腿)开源码开发/微信公众号、小程序、H5多端账号同步/搭建多城市的综合社交生活平台
基于开源技术栈构建的校园圈子系统小程序,整合社交与生活服务功能,涵盖兴趣圈子、私信聊天、资料共享、二手交易、兼职跑腿等六大核心模块。通过多端账号同步(微信公众号/小程序/H5),实现数据实时交互,满足学生群体的多元化需求。项目精准锚定校园市场,以“社交+服务”双轮驱动,提供一站式解决方案,支持快速部署与多校区运营,同时具备广告、佣金、会员等多元变现能力,是打造校园生态的理想工具。
578 2
校园圈子系统小程序(圈子论坛、私信聊天、资料共享、二手交易、兼职,跑腿)开源码开发/微信公众号、小程序、H5多端账号同步/搭建多城市的综合社交生活平台
|
11月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
2004 1
|
11月前
|
存储 JSON 小程序
微信小程序入门之新建并认识小程序结构
微信小程序入门之新建并认识小程序结构
175 1
ly~
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
259 6
|
7月前
|
小程序 数据安全/隐私保护 开发者
【02】微信支付商户申请下户到配置完整流程-微信开放平台申请APP应用-微信商户支付绑定appid-公众号和小程序分别申请appid-申请+配置完整流程-优雅草卓伊凡
【02】微信支付商户申请下户到配置完整流程-微信开放平台申请APP应用-微信商户支付绑定appid-公众号和小程序分别申请appid-申请+配置完整流程-优雅草卓伊凡
393 3
|
7月前
|
存储 小程序 前端开发
微信小程序与Java后端实现微信授权登录功能
微信小程序极大地简化了登录注册流程。对于用户而言,仅仅需要点击授权按钮,便能够完成登录操作,无需经历繁琐的注册步骤以及输入账号密码等一系列复杂操作,这种便捷的登录方式极大地提升了用户的使用体验
2391 12

热门文章

最新文章