当前位置: 首页 > wzjs >正文

两个人做类似的梦 网站seo新站如何快速排名

两个人做类似的梦 网站,seo新站如何快速排名,做淘宝那样的网站,香河做网站shijuewang大家好,我是 V 哥。 使用 Mate 70有一段时间了,系统的丝滑使用起来那是爽得不要不要的,随着越来越多的应用适配,目前使用起来已经和4.3的兼容版本功能差异无碍了,还有些纯血鸿蒙独特的能力很是好用,比如&am…

大家好,我是 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.dtcms.com/wzjs/202463.html

相关文章:

  • 温州建设集团网站建站平台哪个好
  • 遵义网站推广百度关键词排名突然没了
  • 辽宁自助网站建设价格企点qq官网
  • 福田蒙派克二手车天津关键词优化网站
  • 易企秀怎么做网站链接百度平台投诉人工电话
  • 可以做防盗水印的网站seo优化与推广招聘
  • 做彩票网站怎么样全国疫情又严重了
  • 网站建设三层架构实训报告自助建站系统软件
  • 怎样用编程语言做网站云搜索引擎入口
  • dede 分类信息网站 模板最常见企业网站公司有哪些
  • 网站链接锚文字怎么做北京网站优化排名推广
  • 小程序做网站百度推广管家
  • 做打折网站如何3天引流800个人技巧
  • 网站单页面制作怎么免费建公司网站
  • 有全部公司的网站自己建网站怎么推广
  • 延边住房和城乡建设局网站seo搜索优化待遇
  • 图书网站怎么做品牌宣传活动策划方案
  • 域名到期了网站会打不开吗百度近日收录查询
  • 建设网站虚拟主机哈尔滨seo关键词
  • 多个网站 备案武汉网站seo
  • 本地资讯网站做的最好的济南百度公司
  • 代理记账网站模板全网营销有哪些平台
  • 金华网站建设电话手机登录百度pc端入口
  • 公益网站建设小程序开发系统
  • 创新的响应式网站建设企业网站建设平台
  • wordpress有时打不开1688seo优化是什么
  • 长垣县做网站的网站推广什么意思
  • 网站建设成功案例怎么写做百度推广多少钱
  • 专门做衣服特卖的网站今日nba比赛直播
  • 在凡科上建网站靠谱吗百度推广客户端手机版