名词解释
AliOS Things: 阿里云智能IoT团队自研的物联网操作系统
HaaS:全称是Hardware as a Service,阿里云智能IoT团队基于AliOS Things系统推出的硬件即服务
HaaS UI:全称是Hardware as a Service User Interface,是源自AliOS Things操作系统上的一套应用&图形解决方案,支持C/C++和 JS两种开发语言
File JSAPI是HaaS UI提供的一个轻量级文件接口,特别适用于存储小程序运行所需的文件,如文本、图片、视频等资源文件,这些文件都可以通过File JSAPI来存取。
File JSAPI的作用域为当前小程序应用,包含的接口如下:
接口宿主 |
JSAPI |
调用方法 |
接口功能 |
file | saveFile | $falcon.jsapi.file.saveFile({apFilePath: 'xxx'}) |
文件管理 |
getSavedFileInfo | $falcon.jsapi.file.getSavedFileInfo({apFilePath: 'xxx'}) |
||
getFileInfo | $falcon.jsapi.file.getFileInfo({apFilePath: 'xxx'}) |
||
getSavedFileList | $falcon.jsapi.file.getSavedFileList({}) |
||
removeSavedFile |
$falcon.jsapi.file.removeSavedFile({apFilePath: 'xxx'}) |
file.saveFile 是保存文件到本地(本地文件大小总容量限制:10 MB)的 API。
调用 my.saveFile 成功后,可在"MINIAPP_DATAROOT file/appid/"路径下查看保存的文件,其中appid是小程序的id。
入参
Object 类型,属性如下:
属性 |
类型 |
必填 |
描述 |
apFilePath |
String |
是 |
文件路径。 |
callback |
Function |
否 |
回调函数,包含result参数。 |
示例代码
const file = $falcon.jsapi.file; file.saveFile({ apFilePath: 'd:\\demo.jpg', }, result => {console.log(result)});
success 回调函数
属性 |
类型 |
描述 |
apFilePath |
String |
文件保存路径。 |
file.getSavedFileInfo 是获取"MINIAPP_DATAROOT file/appid/"路径下保存的所有文件信息的 API,其中appid是小程序的id。
入参
入参为Object类型,属性如下:
属性 |
类型 |
必填 |
描述 |
apFilePath |
String |
是 |
文件路径。 |
callback |
Function |
否 |
回调函数,包含result参数。 |
示例代码
const file = $falcon.jsapi.file; file.saveFile({ apFilePath: 'd:\\demo.jpg', }, result => { result && !result.error && file.getSavedFileInfo({ apFilePath: result["apFilePath"], }, result => {console.log(result)}); });
getFileInfo 是获取文件信息的 API。
入参
入参为Object类型,属性如下:
属性 |
类型 |
必填 |
描述 |
apFilePath |
String |
是 |
文件路径。 |
callback |
Function |
否 |
回调函数,包含result参数。 |
示例代码
const file = $falcon.jsapi.file; file.getFileInfo({ apFilePath: "/data/mini_app/file/0000000000000001/demo.jpg", }, result => {console.log(result)});
success 回调函数
入参为Object类型,属性如下
名称 | 类型 | 描述 |
size | Number | 文件大小。 |
digest | String | 摘要结果。 |
file.getSavedFileList 是获取保存的所有文件信息的 API。
入参
Object 类型,属性如下:
属性 |
类型 |
必填 |
描述 |
appId |
String |
否 |
小程序的 appId。 |
callback |
Function |
否 |
回调函数,包含result参数。 |
示例代码
const file = $falcon.jsapi.file; file.getSavedFileList({ }, result => { result && !result.error && console.log(result); });
success 回调函数
属性 |
类型 |
描述 |
fileList |
List |
文件列表。 |
File 对象属性
属性 |
类型 |
描述 |
size |
Number |
文件大小。 |
createTime |
Number |
创建时间。 |
apFilePath |
String |
文件路径。 |
file.removeSavedFile 是删除某个保存的文件的 API。
入参
Object 类型,属性如下:
属性 |
类型 |
必填 |
描述 |
apFilePath |
String |
是 |
文件路径。 |
示例代码
const file = $falcon.jsapi.file; file.getSavedFileList({ }, result => { result && !result.error && file.removeSavedFile({ apFilePath: result.fileList[0].apFilePath, }, result => {console.log(result)}); });
success 回调函数
属性 |
类型 |
描述 |
apFilePath |
String |
被删除文件的路径。 |
在使用File JSAPI前,需要先获取$falcon.jsapi的file对象,所有的接口都是通过file对象进行调用的。
const storage = $falcon.jsapi.file;
文件存储操作需要通过步骤1获取的file对象来进行,具体可通过file.saveFile来实现键值对参数的存储,可存储的文件类型有txt、png、jpg、zip等常见类型。
文件类型/文件操作 |
写入操作 |
txt |
支持 |
png |
支持 |
jpg |
支持 |
zip |
支持 |
... | 支持 |
在进行文件存储时,有两种方式,一种是同步存储,另一种是异步存储。同步存储直接返回存储结果,异步存储需要在async函数中操作,通过await返回存储结果。
接口名/参数列表 |
入参1 |
入参2 |
saveFile |
apFilePath : 'xxx' |
(result) => { console.log(result); } |
同步存储方式:
// sync const file = $falcon.jsapi.file; file.saveFile( { apFilePath: "d:\\demo.jpg", }, (result) => { console.log(result); } );
异步存储方式:
// async const file = $falcon.jsapi.file; let result = await storage.setStorage({ key: 'key', // key data: 'storage content', // value }); console.log(result);
其他文件操作也需要通过步骤1获取的file对象来进行,包含getSavedFileInfo、getFileInfo、getSavedFileList和removeSavedFile,也支持同步和异步两种操作。
本节将以保存一张图片为示例,介绍如何去调用File JSAPI,具体包含保存文件、获取保存的文件信息、获取文件信息、获取保存的文件列表和删除文件。调用saveFile(),就可将文件存储到当前小程序的私有文件路径下,以供小程序使用。文件使用完毕后,调用removeSavedFile(),就可将之删除。
从给定apFilePath中获取要保存的文件路径,并调用saveFile()将之保存到小程序的私有文件路径下:
saveFile() { const file = $falcon.jsapi.file; file.saveFile( { apFilePath: "d:\\demo.jpg", }, (result) => { console.log(result); } ); }
要获取某个已保存的文件的信息,可通过调用getSavedFileInfo()实现:
getSavedFileInfo() { const file = $falcon.jsapi.file; file.saveFile( { apFilePath: "d:\\demo.jpg", }, (result) => { result && !result.error && file.getSavedFileInfo( { apFilePath: result["apFilePath"], }, (result) => { console.log(result); } ); } ); }
要获取某个文件的信息,可通过调用getFileInfo()实现:
getFileInfo() { const file = $falcon.jsapi.file; file.getFileInfo( { apFilePath: "d:\\demo.jpg", }, (result) => { console.log(result); } ); }
要获取已保存的文件的列表,可通过调用getSavedFileList()实现:
getSavedFileList() { const file = $falcon.jsapi.file; file.getSavedFileList({}, (result) => { result && !result.error && console.log(result); }); }
删除通过saveFile()保存的文件,可以调用removeSavedFile()实现:
removeSavedFile() { const file = $falcon.jsapi.file; file.getSavedFileList({}, (result) => { result && !result.error && file.removeSavedFile( { apFilePath: result.fileList[0].apFilePath, }, (result) => { console.log(result); } ); }); }
如需更多技术支持,可加入钉钉开发者群,或者关注微信公众号
更多技术与解决方案介绍,请访问阿里云AIoT首页https://iot.aliyun.com/