主机评测网,专注vps、独立服务器等主机评测
最专业的主机评测网站

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

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

云开发 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://vps.caogenba.com.com/68647.html

如今做站的人不多了,多个朋友多条路子,加入站长论坛和大佬们同道交流,Tips:可以免费打广告哦~ 点击立即加入>>

赞(0) 打赏
未经允许不得转载:主机测评 » 如何实现一云多端?打通小程序和移动应用APP的方法

评论 抢沙发

登录

找回密码

注册