华为AppGallery Connect提供了一个云存储(CloudStorage)的服务,号称提供了一个便捷的云端存储服务,利用开发者应用的时候,能够不必关注服务器的部署,间接应用就行。
这个服务近期上线了服务端NodeJS的SDK,我领先体验试用了一下。有趣味的也能够下载codelab钻研一下。
1、环境与利用信息
版本名称 | 集成环境-利用 | 测试设施 |
---|---|---|
cloudstorage-server": "1.0.0" | Window-Node-v14.15.0 npm v6.14.8 Visual Studio Code | PC |
环境:https://developer.huawei.com/consumer/cn/service/josp/agc/index.html
SDK版本:agconnect/cloudstorage-server": "1.0.0"
集成SDK命令:npm install --save @agconnect/cloudstorage-server
2、在AGC上开明云存储:
PS: 云存储服务目前还处于beta状态,应用前应该发邮件去申请开明:
https://developer.huawei.com/consumer/cn/doc/development/AppGallery-connect-Guides/agc-cloudstorage-apply
在我的我的项目 下抉择你的开发我的项目,在构建上面,找到云存储服务,点击开明:
没有Android我的项目的话,能够先本人创立一个。
开明服务的时候,须要先配置存储实例,这里按需配置就能够,我就轻易配置一个。
下一步,还须要配置安全策略,这里应用默认的安全策略就好:
PS:默认的状况是,只有通过身份认证的用户能力进行读写。
3、装置Node.js环境:
NodeJs的装置是通用步骤,我这边就不详细描述,具体的装置步骤,大家能够去网上自行搜寻,我这就说几个重点步骤
1、 下载并且装置Window环境的Node.js安装包:https://nodejs.org/en/download/
2、 装置NodeJS的时候,会主动装置对应的npm,装置实现后,能够通过如下命令查看对应的版本号
3、 对于NodeJS代码的开发,我习惯用的是VSCode, 大家也能够为了依据我这习惯,也装置一个VScode。http://code.visualstudio.com/
4、 装置好当前,再打咱们的我的项目门路,testNodeJSDemo,轻易创立创立一个js文件,写几个惯例的输入:
5、 在VSCode外面运行这个js文件:在VScode左侧的控制台,抉择Run,而后点击Run and Debug,运行的时候,抉择Node.js,而后就能够下方看到输啦
4、SDK集成
1、关上命令行窗口,进入到我的项目目录下,在该目录下执行npm init命令创立package.json文件,参数应用默认的,一路回车即可,无需关注
2、执行如下命令,装置CloudStorage的Server SDK的依赖
npm install --save @agconnect/cloudstorage-server
3、从AGC界面上下载下载Server SDK的认证凭据,并且把下载好的认证凭据放到方才创立的我的项目门路下:,如果没有认证凭据,能够间接创立一个
5、性能开发
a) 初始化:
蕴含两块,一个是初始化Server SDk,一个是初始化Storage实例。
var { AGCClient, CredentialParser } = require("@agconnect/common-server");var credential = CredentialParser.toCredential("./agc-apiclient-testnodejs.json");AGCClient.initialize(credential); const {StorageManagement} = require('@agconnect/cloudstorage-server');
b) 配置存储实例
复制AGC界面上的我的项目桶名,而后执行如下代码初始化
let bucketName = '9105385871708601205-ffeon'; // 配置AGC云端的存储实例
c) 上传文件:
此处我默认上传我的项目门路下的test123.txt文件,你们应用的时候,也能够按需配置。
// uploadFile();function uploadFile() { const storage = new StorageManagement(); const bucket = storage.bucket(bucketName); bucket.upload('./test123.txt') .then(res => console.log(res)) .catch(err => console.log(err)); }
d) 下载文件
此处我默认下载云端根目录下的test123.txt文件,并且将下载好的本地文件,命名成test_download.txt你们应用的时候,也能够按需配置。
const fs = require('fs');// downloadFile();function downloadFile() { const storage = new StorageManagement(); const bucket = storage.bucket(bucketName); const remoteFile = bucket.file('test123.txt'); const localFile = './test_download.txt'; remoteFile.createReadStream() .on('error', err => { }) .on('end', () => { }) .pipe(fs.createWriteStream(localFile))}
f) 删除文件
此处我默认删除云端根目录下的test123.txt文件,你们应用的时候,也能够按需配置。
// deleteFile();function deleteFile() { const storage = new StorageManagement(); const bucket = storage.bucket(bucketName); const file = bucket.file('test123.txt'); file.delete().then(res => { }).catch(err => { }) }
g) 例举全副文件
此处我默认删除云端根目录下的所有文件。
//getFileList();function getFileList() { const storage = new StorageManagement(); const bucket = storage.bucket(bucketName); bucket.getFiles({delimiter: '/'}).then(res => { console.log(res) }).catch(err => { console.log(err); })}
6、性能点验证
1、验证上传性能:
勾销uploadFile();办法前的正文,而后在命令行窗口,执行node CloudStorage.js命令,进行文件的上传。
上传胜利后,也能够AGC管制台上看到上传的test123.txt文件。
2、验证下载
删除downloadFile();办法前的正文,而后在命令行窗口,执行node CloudStorage.js命令,进行文件的下载:反馈如下,没有任何提醒
下载好当前,能够看到门路下,曾经有刚刚下载的test_download.txt文件
3、获取文件列表
删除 getFileList();办法前的正文,而后在命令行窗口,执行node CloudStorage.js命令,查看根目录下的所有文件。命令行窗口显示如下:
显示的文件,和AGC界面显示的文件统一:
4、删除文件:没有提醒
删除 deleteFile ();办法前的正文,而后在命令行窗口,执行node CloudStorage.js命令,进行文件的删除:反馈如下,没有任何提醒
此时AGC界面上,test123.txt也同样被删除了。
7、总结
仅关注NodeJS的开发,就能够在服务端操作我的项目中的文件。再也不必为了服务器的搭建和运维放心,省时省力。而且还提供了相似于管理员模式的web控制台,能够简略直观的对服务器上的文件进行治理。
这个云存储服务,除了最一般的上传下载和删除性能,还包含有列举文件,设置元数据等性能,具体能够看官网文档:
云存储服务开发指南:
https://developer.huawei.com/consumer/cn/doc/development/AppGallery-connect-Guides/agc-cloudstorage-introduction
云存储服务codelab:
https://developer.huawei.com/consumer/cn/codelab/CloudStorage-nodejs/index.html#0
原文链接:https://developer.huawei.com/consumer/cn/forum/topic/0204411103865560354?fid=0101271690375130218
原作者:Mayism