# 下载文件
从对象存储空间下载文件到小程序本地
本文档适用于公众号H5中使用,如果你不是公众号H5,请移步适合的文档
# 请求参数
| 字段 | 说明 | 数据类型 | 默认值 | 必填 | 
|---|---|---|---|---|
| fileID | 云文件 ID | String | - | 是 | 
| config | 配置 | Object | - | 否 | 
| success | 成功回调 | |||
| fail | 失败回调 | |||
| complete | 结束回调 | 
# config 对象定义
| 字段 | 说明 | 数据类型 | 
|---|---|---|
| env | 使用的环境 ID,填写后忽略 init 指定的环境 | String | 
# success 返回参数
| 字段 | 说明 | 数据类型 | 
|---|---|---|
| tempFilePath | 临时文件路径 | String | 
| statusCode | 服务器返回的 HTTP 状态码 | Number | 
| errMsg | 成功为 downloadFile:ok,失败为失败原因 | String | 
# fail 返回参数
| 字段 | 说明 | 数据类型 | 
|---|---|---|
| errCode | 错误码 | Number | 
| errMsg | 错误信息,格式 downloadFile:fail msg | String | 
# 使用示例
# 1. Callback 风格
cloud.downloadFile({
  fileID: 'cloud://test.png', // 对象存储文件ID,从上传文件接口或者控制台获取
  success: res => {
    console.log(res.tempFilePath)
  },
  fail: err => {
    console.error(err)
  }
})
# 2. Promise 风格
cloud.downloadFile({
  fileID: 'cloud://test.png', // 对象存储文件ID,从上传文件接口或者控制台获取
}).then(res => {
  console.log(res.tempFilePath)
}).catch(error => {
  console.error(err)
})
# 3. 完整示例
以下示例代码写入 html 文件,然后在浏览器打开。
云托管不支持未登录模式,请使用以下安全实现:
以上两种方式都可以安全的实现操作,第1个用的是权限管控(可以配置安全规则,由平台维护),第2个是自己和业务结合,由自己维护;请根据业务需要斟酌使用!
<script src="https://web-9gikcbug35bad3a8-1304825656.tcloudbaseapp.com/sdk/1.3.0/cloud.js"></script>
<script>
  window.onload = async function () {
    window.c1 = new cloud.Cloud({
      appid: '公众号AppID', // 运行的公众号APPID
      resourceAppid: '小程序或公众号AppID', // 资源方账号APPID
      resourceEnv: '微信云托管环境ID', // 资源方云环境 ID
      traceUser: true // 记录用户访问
    });
    await window.c1.init();
    const result = await c1.downloadFile({
      fileID: 'cloud://test.png' // 临时路径获取
    })
    console.log(result)
  }
</script>