前置条件
添加 数据同步 SDK 前,请您确保已经将工程接入到 mPaaS。更多信息请参见 基于已有工程使用 ohpmrc 接入。
引入依赖
在项目的 .ohpmrc
中添加如下仓库:
@mpaas:registry=https://mpaas-ohpm.oss-cn-hangzhou.aliyuncs.com/meta
添加 SDK
在 oh-package.json5
中配置所需依赖,其中,当前版本号为 0.0.2
。
{
"license": "",
"devDependencies": {},
"author": "",
"name": "entry",
"description": "Please describe the basic information.",
"main": "",
"version": "1.0.0",
"dependencies": {
"@mpaas/sync-service": "0.0.2"
}
}
配置权限
在 module.json5
中配置所需权限。
"requestPermissions":[
{
"name" : "ohos.permission.GET_NETWORK_INFO",
},
{
"name" : "ohos.permission.SET_NETWORK_INFO",
},
{
"name" : "ohos.permission.INTERNET",
}
]
初始化框架
在使用 数据同步 之前,需先初始化 mPaaS 框架:
export default class EntryAbilityStage extends AbilityStage {
async onCreate() {
const app = this.context;
MPFramework.create(app);
const instance: MPFramework = MPFramework.instance;
const ctx: Context = instance.context
}
}
import 接口
import {MPSync} from '@mpaas/sync-service'
相关接口
接口名称 | 说明 |
initialize(Context context) | 用于初始化接口和数据同步服务。 |
appToForeground() | 用于让客户端 SDK 感知到当前 App 已经启动,使其建立与服务器的网络连接。每次 App 回前台时调用。 |
appToBackground() | 用于让客户端 SDK 感知到当前 App 已经回到后台,使其断开与服务器的网络连接。每次 App 压后台时调用。 |
updateUserInfo(sessionId:string) | 用于登录信息 |
clearUserInfo() | 用于用户登出。 |
registerBiz(biz:string, syncCallback:ISyncCallback) | 用于注册一个接收业务数据的 |
unregisterBiz(bizType:string) | 用于反注册指定同步配置。在获取到同步推送的数据后,客户端 SDK 则不会回调 |
reportMsgReceived(syncMessag:SyncMessage ) | 用于在 |
isConnected():Promise<boolean> | 用于检查当前数据同步服务是否正常。 |
addConectionListener(listener:connectionListener) | 添加监听连接状态。 |
removeConnectionListener(listener:connectionListener) | 删除连接状态监听。 |
使用实例
export default class EntryAbility extends UIAbility {
onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
..
//在ability开始阶段进行初始化相关操作
MPFramework.create(this.context);//初始化
MPFramework.instance.userId = example_userid;//设置userid
MPSync.initialize();//初始化sync
..
}
}
//page代码示例
connectListener:ConnectionListener = {
onConnectionStateChanged: (connectionEvent: ConnectionEvent) => {
let type = connectionEvent.getEventType();
switch (type) {
case ConnectionType.Connecting:
this.connectionMsg = "连接中"
break;
case ConnectionType.Unknown:
this.connectionMsg = "未知"
break;
case ConnectionType.Connected:
this.connectionMsg = "已连接"
break;
case ConnectionType.Disconnected:
this.connectionMsg = "已断开"
break;
case ConnectionType.ConnectFailed:
let message = connectionEvent.getExtras();
this.connectionMsg = "连接失败:" + message
break;
}
}
onPageShow(): void {
MPSync.appToForeground();
MPSync.addConnectionListener(this.connectListener)
}
build() {
Row() {
Column({ space: 20 }) {
Button('初始化', { type: ButtonType.Capsule, stateEffect: true })
.onClick(() => {
let index = 1;
let callback:ISyncCallback= {//消息接收callback示例
onReceiveMessage:(message:SyncMessage):void=>{
let msg = message.msgData;
let obj:object[] = JSON.parse(msg);
let str = "收到消息:\n";
obj.forEach(value=>{
let m:string = getMessageObjString(value);
str += "message:"+index+":"+ m+'\n'
index++
})
this.message = str
},
onReceiveCommand:(message:SyncCommand):void=>{
}
}
MPSync.registerBiz("oneUserSync",callback)//注册biz,
}).width('90%').margin({ top: 15 })
Button('用户绑定', { type: ButtonType.Capsule, stateEffect: true })
.onClick(() => {
MPSync.updateUserInfo("harmony_session")//绑定用户
}).width('90%').margin({ top: 15 })
}
}
.height('100%').alignItems(VerticalAlign.Top)
}