# Donut多端应用-快速开始

# 使用云开发

使用云开发时,需要在 cloud.init 时显式指定云开发环境所在的微信 AppID:

wx.cloud.init({
  appid: 'wx1234567890', // 创建云开发环境的 AppID(小程序、公众号),不是多端应用 AppID
  envid: 'env-id-example', // 云开发环境名称
})

# 多端登录模式

采用以下登录方式,登录成功后,可以无缝使用云开发,和在微信小程序内使用无异。

# 1. 唤起微信小程序登录
# 2. 移动应用微信登录
  • 如果使用的是移动应用微信登录,需要在「微信开发者工具-云开发-更多-环境共享-添加共享」给移动应用 APPID 共享环境
# 3. 其他方式登录
  • 如果使用其他方式登录,如手机号登录,需要在登录后去绑定微信,绑定成功后只用该方式登录也可以使用云开发

注:环境共享时,需要填写的移动应用 APPID为如下所示

# 未登录模式

默认情况下,在多端框架内是无法正常使用云开发的,包括云函数、数据库等。这是因为多端环境中缺失微信登录态信息的(即 cloud.getWXContext 内无 OPENID)。

为此,我们提供了云开发的未登录模式,开发者可以进行以下配置,在多端环境中以未登录态模式使用云开发。

# 1. 开启环境级别开关

为了允许未登录模式用户访问云环境资源,需要在「微信开发者工具-云开发-设置-权限设置-未登录用户访问云资源权限设置」打开相应云环境的开关。

# 2. 配置云函数安全规则

调用云函数时,由于未登录模式的限制,还需要配置云函数的安全规则。参考安全规则如下(云函数 function1 支持未登录模式调用):

{
  // * 为通配符,表示对所有函数适用
  "*": {
    // invoke 表示调用权限控制
    // auth 包含鉴权信息,如果是未登录模式,则 auth == null
    "invoke": "auth != null"
  },
  // 函数名,该规则优先级会高于通配符
  "function1": {
    // 表示允许所有来源调用,包括未登录用户
    "invoke": true
  }
}
# 3. 配置数据库安全规则

访问数据库时,由于未登录模式的限制,还需要配置数据库安全规则。参考安全规则如下(所有用户可读,仅登录后创建者可写):

{
  "read": true,
  "write": "auth != null && doc._openid == auth.openid"
}
# 4. uploadFile 、cloudId 和其他接口

未登录模式下,不支持 wx.cloud.uploadFile 以及 cloudId 等需要登录态的接口。如有上传文件需求,建议使用“多端登录模式”,或者通过腾讯云对象存储等形式直接上传到存储桶中。cloudId 访问云存储建议改以 https url 形式访问。