如何实现一云多端?打通小程序和移动应用APP的方法

本站:VPS参考评测推荐,专注分享VPS服务器优惠信息!若您是商家也可以在本站进行投稿,查看详情!此外我们还提供软文收录、PayPal代付、广告赞助等服务,查看详情!
部分文章发布时间较久远,可能存在未知因素,购买时建议在本站搜索商家名称,可查看相关文章充分了解商家!若非中文页面可使用谷歌浏览器同步翻译!PayPal代付/收录合作

云开发 CloudBase 是一个云集成的后端云服务。采用Serverless架构,免去了移动应用建设中繁琐的主机搭建和运维。使用云开发,可以快速构建完整的小程序/小游戏、H5、Web、手机APP等应用。

Flutter 是目前最流行的跨端开发框架,可以快速开发跨端应用,界面优雅,性能卓越,同时支持 AOT 和 JIT 运行时,兼顾研发效率和应用性能。

通过在云端开发 Flutter 插件,可以在 Flutter 应用中使用云功能、云数据库、云存储等能力,快速构建 Flutter 应用。此外,在微信小程序内,原生提供云开发能力。本文将简介如何打通小程序和Flutter App的云开发环境,实现一云多端。

1、云开发 Flutter 插件

Cloud Development 为 Flutter 提供了 5 个插件,开发者可以按需下载使用。

2、小程序和App的跨平台应用开发

基于云开发和Flutter,通过共享云开发环境,开放用户系统和数据,在App端配置额外的安全保护,实现小程序和应用的跨平台应用开发。

共享云开发环境

目前有两种云开发环境(腾讯云·云开发和小程序·云开发)。微信小程序只能使用小程序·云开发环境。所以,为了达到共享云开发资源的目的,只能创建小程序和云开发的环境,设置成允许应用使用。

(ps:本文后面提到的云开发环境指的是小程序云开发环境)

1、在微信开发者工具中创建小程序云开发环境。

2、登录腾讯云开发控制台,选择登录方式使用微信公众号登录。登录后可以查看和操作步骤1中创建的环境。

3、在登录授权中配置合适的登录方式,即可通过云端开发Flutter插件,在Flutter APP中访问小程序云开发环境。

开放用户系统和数据

微信为开发者提供了一套基于UnionId的用户系统,可以使用UnionId打通微信小程序和Flutter App的用户数据。

1、创建一个数据库集合 todos 并使其公开读取。

2、创建一个getTodosInfo云函数并在云函数内适配

 // 小程序来源  const cloud = require('wx-server-sdk')  cloud.init(({  env: cloud.DYNAMIC_CURRENT_ENV  }))  // Flutter端来源  const tcb = require('tcb-admin-node')  tcb.init({  env: tcb.getCurrentEnv()  })  exports.main = async (event, context) => {  let db, unionid  // 根据来源初始化 db 和 unionid  const source = tcb.parseContext(context).TCB_SOURCE  switch(source) {  // 微信小程序来源  case 'wx_client':  // 微信开发者IDE来源  case 'wx_devtools': {  unionid = cloud.getWXContext().UNIONID  db = cloud.database()  }  // Flutter端来源  case 'web_client': {  unionid = tcb.parseContext(context).WX_UNIONID  db = tcb.database()  }  }  // 以 unionid 为用户索引写入数据  await db.collection('todos').add({  userId: unionid,  todo: 'study tcb'  })  // 以 unionid 为用户索引读取数据  const doc = await db.collection('todos').where({  userId: unionid  }).get()  }

如果在微信小程序中不登录调用云函数,在Flutter App中通过微信登录调用云函数,则两端同一个微信用户获取的数据是一致的。

额外的安全性

在小程序中使用云开发资源有微信提供的安全保护,自然免认证,不需要开发者关心。但是,在 Flutter App 中使用云开发资源时,如果环境信息不慎泄露,就有云开发资源被盗的风险。因此,云开发为App端提供了额外的安全保护能力——移动安全源认证。只有有效的安全凭证才能调用云开发资源。

打开安全设置页面,在移动应用安全源中创建应用凭证。当多个应用共享同一环境时,应为每个应用创建唯一的安全凭证。

在初始化环境时注入安全凭证。

 import 'package:cloudbase_core/cloudbase_core.dart';  import 'package:cloudbase_auth/cloudbase_auth.dart';  // 初始化 CloudBase  CloudBaseCore core = CloudBaseCore.init({  // 填写你的云开发 env  'env': 'your-env-id',  // 填写你的移动应用安全来源凭证  'appAccess': {  // 凭证  'key': 'your-app-access-key',  // 版本  'version': 'your-app-access-version'  }  });

如果安全凭证意外泄露,可以通过升级和更换安全凭证来保护云资源。

写在最后

本文以Flutter插件的云开发为例,简介如何为小程序和应用开发跨平台应用。借助云端开发的其他端SDK,可以将在云端开发应用的能力扩展到更多端。

本文简介如何打通用户系统和数据时,是围绕微信的用户系统构建的,是APP端使用微信登录的必要条件。后续云开发将构建更完善的用户体系,让开发者更轻松地访问多终端数据。

本文由本站刊发,转载请注明:如何实现一云多端?打通小程序和移动应用APP的方法,https://本站.com/68647.html

推荐站内搜索:域名到期查询、免费外网服务器、域名备案网站、域名注册中心、服务器空间租用、个人虚拟主机、云服务器免费域名注册平台、国内免备案服务器、备案信息、