《微信小程序开发从入门到实战》学习四十一

4.3 云开发文件存储

文件存储功能支持将任意数量和格式的文件(如图片和视频)保存在云端,支持 以文件夹的形式将文件归类。

在云开发控制台中,可以对云端保存的文件进行管理。

也可以通过文件存储API对文件进行上传、删除、移动、下载和搜索操作。

4.3.1 在控制台中管理文件存储

云开发控制台的文件存储管理页面如下图所示:

在云开发控制平台,管理文件存储的操作方式与网盘相似 ,

单击按钮可以实现上传文件,删除文件,新建文件夹,删除文件夹。在文件列表里查询到文件名称、FileID、文件大小及更新时间等信息,在当前路径中通过文件名称的前缀搜索文件。

上传的文件有一个唯一的FileID,在小程序基础库2.3.0以上的版本,image组件和video文件组件都支持云开发的FileID,可通过src属性使用对应文件的FileID,代码如下:

<image src="cloud://test-8-1322735059/test.png"/>

在控制台中,可对文件存储的权限设置进行修改。

云开发控制台和服务端API始终有所有文件的读/写权限,

小程序端API的权限控制提供了四个级别的权限,如下所示:

|---------------------|--------------|
| 权限规则 | 使用场景 |
| 所有用户可读,仅创建者可读/写 | 用户头像、用户公开相册等 |
| 仅创建者可读/写 | 私密相册、网盘文件等 |
| 所有用户可读(仅管理端可写) | 文章配图、商品图片等 |
| 所有用户不可读/写(仅管理端可读/写) | 业务日志等 |

(刚刚意识到创建者不是代码创建者,而是指用户创建自己用户头像相册这个创建者。)

4.3.2 上传文件

小程序端和云函数,可使用API将文件上传至云空间文件存储空间。

上传文件与下载文件的小程序API与服务端API不太一样。

在小程序端,使用wx.cloud.uploadFile可以将本地文件上传至云空间,代码如下:

// 使用回调风格的API上传文件,会返回一个uploadTask对象

const uploadTask = wx.cloud.uploadFile({

cloudPath: 'example.png', //上传至云端的路径

filePath: '/imgs/StockSnap_MUT1M3ZKZX.jpg', //本地文件路径

success: res => {

// 上传成功后会返回文件的FileID

// 可以根据具体的使用需求对FileID进行一些操作,例如与其他相关信息一起保存在数据库中

console.log(res.fileID)

},

fail: err => {

console.log(err)

}

})

// 在uploadTask 对象上可以设置上传进度的监听回调

uploadTask.onProgressUpdate(res => {

console.log('上传进度', res.progress)

console.log('已经上传的数据进度', res.totalBytesSent)

console.log('预期需要上传的数据总长度', res.totalBytesExpectedToSend)

})

// 也可以通过uploadTask上面的abort方法取消上传任务

// uploadTask.abort()

//上传文件同样也支持Promise风格的API,但是不再返回uploadTask对象

wx.cloud.uploadFile({

cloudPath:'example.jpg',

filePath: '/imgs/StockSnap_MUT1M3ZKZX.jpg'

}).then(res => {

//get resource ID

console.log(res.fileID)

}).catch(error => {

//handle error

})

如果云空间已经存在该文件,则上传时会覆盖源文件。

如果希望将文件上传云空间的某个文件夹下,只需要将文件夹名称放入cloudPath,加上"/".

cloudPath: 'test/example.png'

上传文件的本地路径可以通过小程序提供的一些API获取,比如从相册选取图片的APIwx.chooseImage,代码如下:

wx.chooseImage({

count: 1,//最多选取几张图片

success(res) {

// tempFilePath是一个string[]类型的值,数组的每一项代表了用户选取的图片的临时地址

const tempFilePaths = res.tempFilePaths

wx.cloud.uploadFile({

cloudPath: 'test/example.jpg',

filePath:tempFilePaths[0] //由于限制了count为1,因此数组中只有1个元素

})

}

})

相关推荐
2501_915918416 分钟前
Flutter 加固方案对比与实战,多工具组合的跨平台安全体系(Flutter App 加固/IPA 成品混淆/Ipa Guard CLI/自动化安全流程)
安全·flutter·ios·小程序·uni-app·自动化·iphone
lingggggaaaa16 分钟前
小迪安全v2023学习笔记(一百四十五讲)—— Webshell篇&魔改冰蝎&打乱特征指纹&新增加密协议&过后门查杀&过流量识别
笔记·学习·安全·魔改冰蝎·免杀对抗·免杀技术
泽_浪里白条18 分钟前
UniApp + Vue3 开发微信小程序数字人:TTS PCM 音频流与 SVGA 动画同步实战
微信小程序
小蒜学长32 分钟前
springboot基于Java的校园导航微信小程序的设计与实现(代码+数据库+LW)
java·spring boot·后端·微信小程序
说私域1 小时前
定制开发AI智能名片S2B2C商城小程序的发展与整合资源策略研究
人工智能·小程序
落羽的落羽1 小时前
【C++】现代C++的新特性constexpr,及其在C++14、C++17、C++20中的进化
linux·c++·人工智能·学习·机器学习·c++20·c++40周年
小苏兮1 小时前
【把Linux“聊”明白】编译器gcc/g++与调试器gdb/cgdb:从编译原理到高效调试
java·linux·运维·学习·1024程序员节
im_AMBER1 小时前
React 11 登录页项目框架搭建
前端·学习·react.js·前端框架
WenGyyyL2 小时前
微信小程序开发——第二章:微信小程序开发环境搭建
开发语言·python·微信小程序
TiAmo zhang3 小时前
微信小程序开发案例 | 个人相册小程序(上)
微信小程序·小程序