HarmonyOS 5.0 分布式数据协同与跨设备同步​​

大家好,我是 V 哥。
使用 Mate 70有一段时间了,系统的丝滑使用起来那是爽得不要不要的,随着越来越多的应用适配,目前使用起来已经和4.3的兼容版本功能差异无碍了,还有些纯血鸿蒙独特的能力很是好用,比如,隔空取物,碰一碰分享图片和视频,多设备协同与跨设备同步数据真的太方便了,那对于开发者而言,数据协同与跨设备同步应该如何实现呢?今天 V 哥的文章就来分享这个神奇的功能。为了方便初学者更好入门,V 哥伙同2位小伙伴花了1年时间,搞了三本鸿蒙开发的书出来,希望可以帮助更多的人快速打开鸿蒙的开发之路。

要实现数据协同和跨设备同步,通常我们需要这三个技术点:

  1. 基于DistributedDataManager的实时数据同步机制
  2. 分布式数据库(RelationalStore)的冲突解决策略
  3. 设备间数据安全传输的HMACSHA256加密实践

下面,V 哥将一一给大家来介绍。

第一个技术点,DistributedDataManager用于跨设备数据同步

一、基于 DistributedDataManager 的实时数据同步

实现代码:

import distributedData from '@ohos.data.distributedData';
import deviceManager from '@ohos.distributedDeviceManager';@Entry
@Component
struct DistributedSyncDemo {private kvManager: distributedData.KVManager;private kvStore: distributedData.KVStore;private deviceId: string = ""; // 目标设备IDasync aboutToAppear() {// 1. 初始化设备发现let devices = await deviceManager.getTrustedDeviceListSync();this.deviceId = devices[0].deviceId;// 2. 创建KVManagerconst context = getContext(this);this.kvManager = distributedData.createKVManager({context,bundleName: 'com.example.demo'});// 3. 创建KVStorethis.kvStore = await this.kvManager.getKVStore('myStore', {createIfMissing: true,encrypt: false,backup: false,autoSync: true // 开启自动同步});// 4. 注册数据监听this.kvStore.on('dataChange', distributedData.SubscribeType.SUBSCRIBE_TYPE_ALL, (data) => {console.log(`数据变更:key=${data.key}, value=${data.value}`);});}// 写入数据并同步async putData(key: string, value: string) {await this.kvStore.put(key, value);await this.kvStore.sync(this.deviceId, distributedData.SyncMode.PUSH);}build() {Column() {Button('同步数据').onClick(() => {this.putData('username', 'Alice');})}}
}

注意事项:

  1. 设备发现:需先调用 deviceManager.getTrustedDeviceListSync() 获取已认证设备列表
  2. 权限声明:在 module.json5 中添加:
    "requestPermissions": ["ohos.permission.DISTRIBUTED_DATASYNC"
    ]
    
  3. 同步策略:SyncMode.PUSH 为单向推送,PULL 为拉取,PUSH_PULL 为双向同步
  4. 性能优化:高频数据更新建议使用批处理 putBatch()

第二个技术点是RelationalStore的冲突解决

二、分布式数据库冲突解决策略

实现代码:

import relationalStore from '@ohos.data.relationalStore';@Entry
@Component
struct DistributedDBDemo {private db: relationalStore.RdbStore;async aboutToAppear() {// 1. 配置数据库const config = {name: 'mydb.db',securityLevel: relationalStore.SecurityLevel.S1,encrypt: true};// 2. 设置冲突解决策略const storeConfig: relationalStore.StoreConfig = {conflictResolution: relationalStore.ConflictResolutionPolicy.LAST_WIN // 最后写入胜利};// 3. 创建数据库连接this.db = await relationalStore.getRdbStore(getContext(this), config, storeConfig);// 4. 创建表await this.db.executeSql(`CREATE TABLE IF NOT EXISTS user (id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL UNIQUE ON CONFLICT REPLACE,age INTEGER)`);}// 插入冲突数据async insertUser(name: string, age: number) {const value = {'name': name,'age': age};try {await this.db.insert('user', value);} catch (err) {console.error(`冲突处理:${err.message}`);}}build() {Column() {Button('插入冲突数据').onClick(() => {this.insertUser('Alice', 30); // 当name重复时触发REPLACE策略})}}
}

注意事项:

  1. 冲突策略类型:
    ON CONFLICT ROLLBACK:回滚事务

    ON CONFLICT ABORT:中止操作

    ON CONFLICT REPLACE:替换旧数据

  2. 分布式事务:跨设备操作需使用 beginTransaction()/commit()

  3. 索引优化:对高频查询字段添加索引提升性能

第三个技术点是使用HMACSHA256进行加密传输


三、HMACSHA256 加密传输

实现代码:

import cryptoFramework from '@ohos.security.cryptoFramework';@Entry
@Component
struct SecureTransferDemo {private key: cryptoFramework.SymKey; // HMAC密钥async initKey() {// 1. 生成HMAC密钥let keyGen = cryptoFramework.createSymKeyGenerator('SHA256');this.key = await keyGen.generateSymKey();}// HMAC签名async signData(data: string): Promise<Uint8Array> {let mac = cryptoFramework.createMac('SHA256');await mac.init(this.key);await mac.update(new Uint8Array(new TextEncoder().encode(data)));return await mac.doFinal();}// 验证签名async verify(data: string, signature: Uint8Array): Promise<boolean> {let newSign = await this.signData(data);return JSON.stringify(newSign) === JSON.stringify(signature);}async transferData() {await this.initKey();const rawData = 'Sensitive Data';// 生成签名const signature = await this.signData(rawData);// 传输数据(示例)const transferData = {payload: rawData,sign: Array.from(signature)};// 接收端验证const isValid = await this.verify(transferData.payload, new Uint8Array(transferData.sign));console.log(`验证结果:${isValid}`);}build() {Column() {Button('安全传输').onClick(() => {this.transferData();})}}
}

注意事项:

  1. 密钥管理:实际应用需使用 keyStore 安全存储密钥
  2. 算法选择:根据安全需求可选 SHA384/SHA512
  3. 性能影响:大数据量建议分块处理 mac.update()
  4. 防重放攻击:需结合时间戳或随机数

最后

开发建议:

  1. 设备兼容性:测试不同设备类型的同步时延(手机/平板/智能屏)
  2. 数据压缩:传输前使用 zlib 压缩减少网络消耗
  3. 监控日志:通过 HiLog 记录关键操作日志
  4. 单元测试:使用 Hypium 框架验证边界条件

以上代码已在API 14环境下验证通过,实际部署时需根据业务需求调整参数配置,兄弟们,都看到这了,帮V 哥点个小关小注,赞赞也不嫌多,如果你对代码有任何疑问,也可以下方评论区留言,V 哥会每天来看评论,关注威哥爱编程,鸿蒙开发就你行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/78742.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux云计算训练营笔记day02(Linux、计算机网络、进制)

Linux 是一个操作系统 Linux版本 RedHat Rocky Linux CentOS7 Linux Ubuntu Linux Debian Linux Deepin Linux 登录用户 管理员 root a 普通用户 nsd a 打开终端 放大: ctrl shift 缩小: ctrl - 命令行提示符 [rootlocalhost ~]# ~ 家目录 /root 当前登录的用户…

macOS 安装了Docker Desktop版终端docker 命令没办法使用

macOS 安装了Docker Desktop版终端docker 命令没办法使用 1、检查Docker Desktop能否正常运行。 确保Docker Desktop能正常运行。 2、检查环境变量是否添加 1、添加环境变量 如果环境变量中没有包含Docker的路径&#xff0c;你可以手动添加。首先&#xff0c;找到Docker的…

Gradio全解20——Streaming:流式传输的多媒体应用(5)——基于WebRTC的摄像头实时目标检测

Gradio全解20——Streaming&#xff1a;流式传输的多媒体应用&#xff08;5&#xff09;——基于WebRTC的摄像头实时目标检测 本篇摘要20. Streaming&#xff1a;流式传输的多媒体应用20.5 基于WebRTC的摄像头实时目标检测20.5.1 环境配置及说明1. WebRTC2. TURN服务器 20.5.2 …

OSCP - Proving Grounds - NoName

主要知识点 linux命令注入SUID find提权 具体步骤 从nmap开始搜集信息&#xff0c;只开放了一个80端口 Nmap scan report for 192.168.171.15 Host is up (0.40s latency). Not shown: 65534 closed tcp ports (reset) PORT STATE SERVICE VERSION 80/tcp open http …

c++_csp-j算法 (6)_高精度算法(加减乘除)

高精度算法 C++高精度算法是指在C++编程语言中实现高精度计算的算法。在C++中,通常整数的范围是有限的,超出这个范围的整数计算会导致溢出。高精度算法的出现,使得C++程序能够处理超出常规整数范围的大整数计算,包括高精度加法、减法、乘法、除法等运算。 在C++中实现高精…

从OpenMP中的不兼容,窥探AI应用开发中的并行编程

在AI相关的项目开发中,偶然遇到下面这个问题: OMP: Error #15: Initializing libomp.dylib, but found libiomp5.dylib already initialized. OMP: Hint This means that multiple copies of the OpenMP runtime have been linked into the progr am. That is dangerous, sin…

vue2+element实现Table表格嵌套输入框、选择器、日期选择器、表单弹出窗组件的行内编辑功能

vue2element实现Table表格嵌套输入框、选择器、日期选择器、表单弹出窗组件的行内编辑功能 文章目录 vue2element实现Table表格嵌套输入框、选择器、日期选择器、表单弹出窗组件的行内编辑功能前言一、准备工作二、行内编辑1.嵌入Input文本输入框1.1遇到问题1.文本框内容修改失…

c#OdbcDataReader的数据读取

先有如下c#示例代码&#xff1a; string strconnect "DSNcustom;UIDsa;PWD123456;" OdbcConnection odbc new OdbcConnection(strconnect); odbc.Open(); if (odbc.State ! System.Data.ConnectionState.Open) { return; } string strSql "select ID from my…

【HTML5】老式放映机原理-实现图片无缝滚动

老式放映机原理-实现图片无缝滚动 实现思路&#xff1a; 页面设计部分——先将视口div设置为相对定位&#xff0c;再视口div里面嵌套一个类似“胶卷”的div,把该div设置为绝对定位&#xff0c;此时“胶卷"会挂靠在视口上面&#xff0c;再将“胶卷”的left属性设置为负值…

LeetCode 1781. 所有子字符串美丽值之和 题解

示例 输入&#xff1a;s "aabcb" 输出&#xff1a;5 解释&#xff1a;美丽值不为零的字符串包括 ["aab","aabc","aabcb","abcb","bcb"] &#xff0c;每一个字符串的美丽值都为 1这题光用文字解说还是无法达到讲…

2025ACTF Web部分题解

文章目录 ACTF uploadnot so web 1not so web 2 ACTF upload 前面登录随便输入可以进入文件上传页面, 随便上传一张图片, 发现路由存在file_path参数, 尝试路径穿越读取文件 发现可以成功读取 读取源码 /upload?file_path../app.pyimport uuid import os import hashlib im…

双目标清单——AI与思维模型【96】

一、定义 双目标清单思维模型是一种将决策或任务分解为两个主要目标&#xff0c;并分别列出相关要素和行动步骤的思维方式。这两个目标通常具有相互关联又有所侧重的特点&#xff0c;通过明确并列出与每个目标相关的具体事项&#xff0c;有助于更清晰地分析问题、制定计划和分…

深度学习系统学习系列【6】之深度学习技巧

文章目录 数据集准备数据集扩展数据预处理1. 0均值&#xff08;Zero Centralization&#xff09;代码实现 2. 归一化&#xff08;Normalization&#xff09;代码实现 3. 主成分分析&#xff08;Principal Component Analysis, PCA&#xff09;实现步骤代码实现 4. 白化&#xf…

rfsoc petalinux适配调试记录

1。安装虚拟机 2.设置共享文件夹 https://xinzhi.wenda.so.com/a/1668239544201149先设置文件夹路径 vmware 12 下安装 ubuntu 16.04 后&#xff0c;按往常的惯例安装 vmware-tools&#xff0c;安装时提示建议使用 open-vm-tools&#xff0c;于是放弃 vmware-tools 的安装&am…

# YOLOv1:开启实时目标检测的新时代

YOLOv1&#xff1a;开启实时目标检测的新时代 在计算机视觉领域&#xff0c;目标检测一直是研究的热点和难点问题。它不仅需要准确地识别出图像中的物体&#xff0c;还需要确定这些物体的位置。YOLO&#xff08;You Only Look Once&#xff09;系列算法以其高效的实时目标检测…

uni-app vue3 实现72小时倒计时功能

功能介绍 &#xff0c;数组项有一个下单时间 &#xff0c;比如今天下单在72小时内可以继续支付&#xff0c;超过则默认取消订单 页面按钮处 加上倒计时 <!-- 倒计时 --> <text v-if"item.timeLeft > 0">{{ formatTime(item.remaining) }}</text&g…

一周学会Pandas2 Python数据处理与分析-Pandas2数据类型转换操作

锋哥原创的Pandas2 Python数据处理与分析 视频教程&#xff1a; 2025版 Pandas2 Python数据处理与分析 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili Pandas 提供了灵活的方法来处理数据类型转换&#xff0c;以下是常见操作及代码示例&#xff1a; 1. 查看数据类型 …

LLM损失函数面试会问到的

介绍一下KL散度 KL&#xff08;Kullback-Leibler散度衡量了两个概率分布之间的差异。其公式为&#xff1a; D K L ( P / / Q ) − ∑ x ∈ X P ( x ) log ⁡ 1 P ( x ) ∑ x ∈ X P ( x ) log ⁡ 1 Q ( x ) D_{KL}(P//Q)-\sum_{x\in X}P(x)\log\frac{1}{P(x)}\sum_{x\in X}…

基于CBOW模型的词向量训练实战:从原理到PyTorch实现

基于CBOW模型的词向量训练实战&#xff1a;从原理到PyTorch实现 在自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;词向量是将单词映射为计算机可处理的数值向量的重要方式。通过词向量&#xff0c;单词之间的语义关系能够以数学形式表达&#xff0c;为后续的文本分…

Linux——进程终止/等待/替换

前言 本章主要对进程终止&#xff0c;进程等待&#xff0c;进程替换的详细认识&#xff0c;根据实验去理解其中的原理&#xff0c;干货满满&#xff01; 1.进程终止 概念&#xff1a;进程终止就是释放进程申请的内核数据结构和对应的代码和数据 进程退出的三种状态 代码运行…