-

前面章节分享了云函数、数据库,基本上可以完成一个简单应用开发了。但是一款应用应该还会有图片、视频之类的,那么这些数据存放在哪呢?那就是云存储。云存储每个云厂商的叫法不一样,有的叫 OSS、有的叫 COS。

我们打开腾讯云云开发控制台,如下图是云开发的云存储界面。

云存储的作用或者说能力有:

  • 可以设置访问权限,比如公开图片或者私人相册,可以点击【权限设置】进行设置;
  • 可以作为图片上传的图床,比如存放 icon 、image、svg......
  • 可以作为一些素材或者物料仓库,例如存放 pdf、word、excel......
  • 云开发的云存储默认是 CDN 加速的;

下面的环节,都是在云函数的基础上操作的,假如对云函数不了解,可以阅读编写第一个云函数

上传文件

我们可以使用 云开发 Node.js SDK,在云函数中进行图片的上传。

'use strict';
const tcb = require("tcb-admin-node")
const fs = require("fs")
const app = tcb.init({
  env: '你的环境 ID'
})


exports.main = async (event, context) => {

    
    // uploadFile 上传文件
    let data = await app.uploadFile({
        cloudPath: "/test-00001.jpg",
        // fileContent: buffer 或要上传的文件可读流
        // 后续会将更简单的方法,在前端直接通过 JS-SDK 上传
        fileContent: fs.createReadStream('./test.png') 
    })


    return {
        status: 1,
        file_id: res.fileID
    }


}

下载文件

有了文件上传,就有文件的下载动作。

'use strict';
const tcb = require("tcb-admin-node")
const fs = require("fs")
const app = tcb.init({
  env: '你的环境 ID'
})


exports.main = async (event, context) => {


  // downloadFile 下载图片
  let res = await app.downloadFile({
    fileID: '云存储中文件的 fileID',
  })


  // fileContent 类型为 Buffer
  return res.fileContent
}

获取文件的 CDN 访问路径

一般情况,手动上传的文件,都可以复制到 CDN 的访问链接。但是如果是代码大批量上传的,我们可以写程序获取,例如获取用户的头像。



const tcb = require('tcb-admin-node')


const app = tcb.init({
  env: '你的环境 ID'
})


exports.main = async (event, context) => {


  // getTempFileURL 获取 CDN 访问地址
  let res = await app.getTempFileURL({
    // fileID 数组
    fileList: ['fileID-1', 'fileID-2']
  })


  res.fileList.forEach(item => {
    // 打印文件访问链接
    console.log(item.tempFileURL) 
  })


}

删除文件

删除文件也比较简单。

const tcb = require('tcb-admin-node')


const app = tcb.init({
  env: '你的环境 ID'
})


exports.main = async (event, context) => {


  // deleteFile 删除文件
  let res = await app.deleteFile({
    fileList: [
        'cloud://a/b/c',
        'cloud://d/e/f'
    ]
  })


  return res.fileList


}