uniapp chooseVideo和uploadFile 选择视频或照片上传抖快平台踩坑

先贴代码

复制代码
uni.chooseVideo({
	sourceType: ['album'],
	fail:(err)=>{
		console.log(TAG, "==chooseVideo-fail==err:", err)
		page.resetUploadFileField()
		if (err.errNo == 10200 || 'chooseVideo:fail take video fail' == err.errMsg || 'chooseVideo:fail auth deny' == err.errMsg) {
			ToastUtil.showTipToast(`前往手机设置-应用打开${getHostName_()}相册权限`)
		} else if (err.errNo != 10502 && 'chooseVideo:fail cancel' != err.errMsg) {
			ToastUtil.showTipToast("获取上传文件异常:" + JSON.stringify(err))
		} 
	},
	success:(res)=>{
		console.log(TAG, "==chooseVideo-success==res:", res)
		if (res && res.tempFilePath && res.duration >= 3 && res.size <= 500*1024*1024) {
			page.uploadFile = res.tempFilePath
			page.uploadFileDuration = res.duration
			page.uploadFileSize = res.size
			page.chooseVideoSucc = true
			page.uploadMedia()
		},				
	})

			//上传视频
			async uploadMedia() {
				let page = this
				//原生上传方法
				if (this.chooseVideoSucc) {
					this.isUploading = true
					let header = {
					}
					console.log(TAG,"==uploadMedia chooseVideoSucc 开始上传==")
					this.uploadTask = uni.uploadFile({
						url: res.data.host, //上传地址
						filePath: page.uploadFile,
						fileType: 'video',
						name: 'file',//重要标识
						header: header,
						formData:{
							//阿里云os端相关配置参数由后台下发
							"key":res.data.dir,
							"OSSAccessKeyId":res.data.access_id,
							"policy":res.data.policy,
							"signature":res.data.signature,
							"callback":res.data.callback,
						},
						success(res) {
							console.log(TAG, "==上传成功==res:", res)
						},
						fail(err) {
							console.log(TAG, "==上传失败==err:", err)
						}
					})

					//上传进度监听,条件编译
					this.uploadTask.onProgressUpdate((res) => {
						console.log('onProgressUpdate==res:',res)
						//快手浮点型0-1
						// #ifdef MP-KUAISHOU
						page.uploadProgress = (res.progress.toFixed(2))*100
						// #endif
						
						//非快手浮点型1.0-100.0
						// #ifndef MP-KUAISHOU
						page.uploadProgress = res.progress
						// #endif				
					})
				}
			},

上面的代码看着是真恶心,而且快手端根本达不到产品的要求,小吐槽一下。。。

先做个小笔记,学习中遇到的一个问题:运算符双问号 ?? 在快手的template标签中会编译报错,抖音是可以正常解析的。

以下是坑::::

  1. 申请访问相册权限拒绝后返回区别:抖音有明确的错误码: err.errNo,快手只有err.errMsg,
    而且快手自己没有"图片和视频"访问权限,和有权限了,跳转到相册选择页直接退出不选择内容,都在api回调中返回 errMsg:chooseVideo:fail take video fail,
    真的很不规范好吧
  2. uni.authorize({scope: "scope.camera",})这个玩意没法用,反馈的结果完全没有参考意义
  3. uni.openSetting({success(authSetting) {},fail() { }),这个方法打开的是小程序宿主对向程序开放的权限页面,在小程序的三个点里面也能拉起,实际真没啥意义
  4. 上传进度,快手是0-1的浮点型,抖音是1-100的浮点型;还有那个fileType: 'video',name: 'file',当时name随便填的,没想到把我后端一直收不到数据,但是上传进度是正常的,真是服了,到处屎坑
  5. 上传阿里云OSS的坑,如果使用阿里云node.js 的方法直接跨域传到阿里云上,是万万行不通的,真的把我折磨了两天,oss-sdk和api根本用不了,劝各位往后放弃直传,只能让后端透传创建一个我们自己的域名,给到相应的阿里云oss的key和secret也已完成间接直传
  6. 最大的坑是从阿里云跨域下载文件,到目前位置依然没有解决办法,小程序的网络请求都默认添加上了referer,这个需要在阿里云后端配置白名单,出于安全考虑,不让配都快自己的referer,所以没法直接下载,搞我半条命
相关推荐
八八在线工具1 小时前
在线m3u8转MP4
音视频·视频编解码·工具
EasyCVR2 小时前
EasyCVR视频融合技术在粮仓智能监管系统中的应用设计与实现
音视频
_OP_CHEN2 小时前
【从零开始的Qt开发指南】(二十二)Qt 音视频开发宝典:从音频播放到视频播放器的实战全攻略
开发语言·c++·qt·音视频·前端开发·客户端开发·gui开发
美狐美颜sdk3 小时前
全局美颜SDK开发方案:直播平台如何实现系统级美颜
人工智能·音视频·美颜sdk·视频美颜sdk·美狐美颜sdk
iOS阿玮3 小时前
死了么 - 官方正版惨遭下架,背后原因竟是ta!
uni-app·app·apple
2501_915921436 小时前
如何在苹果手机上面进行抓包?iOS代理抓包,数据流抓包
android·ios·智能手机·小程序·uni-app·iphone·webview
阿正的梦工坊7 小时前
使用豆包多模态API(doubao-seed-1-8模型)分析小红书视频内容pyhton代码
人工智能·音视频
CoookeCola7 小时前
新一代 AI 模型与多模态 Agent 项目(2026/01/14近期)
人工智能·计算机视觉·ai作画·开源·音视频
00后程序员张7 小时前
iOS APP 性能测试工具,监控CPU,实时日志输出
android·ios·小程序·https·uni-app·iphone·webview
EasyCVR8 小时前
基于视频融合平台EasyCVR的变电站智慧消防远程监控系统设计与实现
音视频