| 主机参考:VPS测评参考推荐/专注分享VPS服务器优惠信息!若您是商家可以在本站进行投稿,查看详情!此外我们还提供软文收录、PayPal代付、广告赞助等服务,查看详情! |
| 我们发布的部分优惠活动文章可能存在时效性,购买时建议在本站搜索商家名称可查看相关文章充分了解该商家!若非中文页面可使用Edge浏览器同步翻译!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端使用微信登录的必要条件。后续云开发将构建更完善的用户体系,让开发者更轻松地访问多终端数据。
这几篇文章你可能也喜欢:
- 迷你计划对离线妇女服装店的运营效率的影响和作用(微信Mini计划和服装商店)
- 迷你节目是展览的新体验,使展览互动更加顺畅,更聪明! (展览微信的官方帐户)
- 如何在微信中实现双向数据绑定(在微信中的双向数据绑定)
- 结合WX.Request和微信的承诺
- 实施微信小程序发送模板消息(小程序发送消息)
本文由主机参考刊发,转载请注明:如何实现一云多端?打通小程序和移动应用APP的方法 https://zhujicankao.com/68647.html
主机参考














评论前必须登录!
注册