VPS参考测评推荐
专注分享VPS主机优惠信息
衡天云优惠活动
荫云优惠活动
wexlayer优惠活动

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

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

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

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

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

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

1、云开发 Flutter 插件

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

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

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://zhujicankao.com/68647.html

【腾讯云】领8888元采购礼包,抢爆款云服务器 每月 9元起,个人开发者加享折上折!
打赏
转载请注明原文链接:主机参考 » 如何实现一云多端?打通小程序和移动应用APP的方法
主机参考仅做资料收集,不对商家任何信息及交易做信用担保,购买前请注意风险,有交易纠纷请自行解决!请查阅:特别声明

评论 抢沙发

评论前必须登录!