跳到主要内容

应用间配置共享 (ArkTS)

场景介绍

应用间配置共享通过集中管理公共配置信息,在不同应用间共享配置,提升协作效率。

从API version 20开始,支持应用间配置共享。

运作机制

应用间配置共享运作机制如下所示:

  1. 配置发布方(即数据提供方):负责提供默认共享配置项,并能动态修改配置项信息。当前支持静态配置和动态配置两种配置方式。
    • 静态配置:应用包在安装时提供的默认共享配置项(不依赖应用启动即生效)。
    • 动态配置:配置发布方通过调用相关接口可以动态新增、删除或修改配置项(不依赖应用升级)。
  2. 配置访问方(即数据访问方):可通过调用接口获取配置信息、或者监听/取消监听配置变化。

约束与限制

一个应用最多可以发布32个配置项,这个数量是静态配置与动态配置的总和。

接口说明

以下接口为应用间配置共享的相关接口。详细接口和说明,请参考应用间配置共享接口

公共接口

接口名称描述
createDataProxyHandle(): Promise<DataProxyHandle>创建数据代理操作句柄,可用于订阅、发布、获取等操作。

配置发布方接口

接口名称描述
publish(data: ProxyData[], config: DataProxyConfig): Promise<DataProxyResult[]>发布或修改配置项。
delete(uris: string[], config: DataProxyConfig): Promise<DataProxyResult[]>删除配置项。

配置访问方接口

接口名称描述
get(uris: string[], config: DataProxyConfig): Promise<DataProxyGetResult[]>获取配置项信息。
on(event: 'dataChange', uris: string[], config: DataProxyConfig, callback: AsyncCallback<DataProxyChangeInfo[]>): DataProxyResult[]监听配置项变化。
off(event: 'dataChange', uris: string[], config: DataProxyConfig, callback?: AsyncCallback<DataProxyChangeInfo[]>): DataProxyResult[]取消监听配置项变化。

配置发布方

module.json5 配置

配置发布方需要配置module.json5文件中的crossAppSharedConfig字段,通过crossAppSharedConfig字段引用shared_config.json文件,shared_config.json为共享配置文件,定义了应用希望与其他应用共享的配置项。共享配置文件需放置在工程resources/base/profile目录下,并通过$资源访问方式引用。

{
"module":{
"crossAppSharedConfig": "$profile:shared_config"
}
}

共享配置文件shared_config.json的文件名"shared_config"可自定义,根节点名称为crossAppSharedConfig,为对象数组,标识当前共享配置项的数量。(一个应用最多可以发布32个配置项,这个数量是静态配置项与动态配置项的总和。静态配置项数量超过32时,只解析前32个符合crossAppSharedConfig字段配置说明要求的配置项,其余配置项不生效。)

crossAppSharedConfig字段配置说明:

属性名称含义数据类型必填
uri共享配置项的全局唯一标识。固定格式为"datashareproxy://{bundleName}/{path}",其中bundleName为配置发布方应用的bundleName,path可随意填写,但同一应用内不允许重复。uri最大长度为256字节。字符串
value共享配置项的值,最大长度为4096字节。字符串
allowList允许访问该共享配置项的应用程序列表。数组最大长度为256,超过256的部分不生效。数组中每个元素为应用的appIdentifier,单个appIdentifier为只包含数字的字符串,最大长度为128字节,超过128字节的appIdentifier不会生效。可使用getBundleInfoForSelf接口来获取当前应用的appIdentifier。字符串数组
{
"crossAppSharedConfig": [
{
"uri": "datashareproxy://com.example.example/key1",
"value": "SHARED_CONFIG_DEMO1",
"allowList": ["6917573629901742292"]
},
{
"uri": "datashareproxy://com.example.example/key2",
"value": "SHARED_CONFIG_DEMO2",
"allowList": ["6917573298752100864", "6917573298752100864"]
}
]
}

静态配置

应用包在安装时提供的默认共享配置项,即在应用安装过程中,预先定义并设置好的共享配置项,这些配置项不依赖应用的启动即可生效。

动态配置

可通过调用publish接口或delete接口,动态新增、删除或修改配置项。

  • 通过调用publish接口发布或修改配置项。

    function publishSharedConfig() {
    dataShare.createDataProxyHandle().then((dataProxyHandle) => {
    const newConfigData: dataShare.ProxyData[] = [
    {
    uri: 'datashareproxy://com.samples.shareconfig/config1',
    value: 'Value1',
    allowList: [
    'appIdentifier1',
    'appIdentifier2'
    ]
    },
    {
    uri: 'datashareproxy://com.samples.shareconfig/config2',
    value: 'Value2',
    allowList: [
    'appIdentifier3',
    'appIdentifier4'
    ]
    }
    ];
    const config: dataShare.DataProxyConfig = {
    type: dataShare.DataProxyType.SHARED_CONFIG,
    };
    dataProxyHandle.publish(newConfigData, config).then((results: dataShare.DataProxyResult[]) => {
    results.forEach((result) => {
    console.info(`URI: ${result.uri}, Result: ${result.result}`);
    });
    }).catch((error: BusinessError) => {
    console.error('Error publishing config:', error);
    });
    }).catch((error: BusinessError) => {
    console.error('Error creating DataProxyHandle:', error);
    });
    }
  • 通过调用delete接口删除配置项。

    function deleteSharedConfig() {
    dataShare.createDataProxyHandle().then((dataProxyHandle) => {
    const urisToDelete: string[] = [
    'datashareproxy://com.samples.shareconfig/config1',
    'datashareproxy://com.samples.shareconfig/config2'
    ];
    const config: dataShare.DataProxyConfig = {
    type: dataShare.DataProxyType.SHARED_CONFIG,
    };
    dataProxyHandle.delete(urisToDelete, config).then((results: dataShare.DataProxyResult[]) => {
    results.forEach((result) => {
    console.info(`URI: ${result.uri}, Result: ${result.result}`);
    });
    }).catch((error: BusinessError) => {
    console.error('Error deleting config:', error);
    });
    }).catch((error: BusinessError) => {
    console.error('Error creating DataProxyHandle:', error);
    });
    }

配置访问方

配置访问方可以通过调用get、on或off接口来获取配置信息或监听/取消监听配置变化。

获取配置项信息

使用get接口获取配置信息。

function getSharedConfig() {
dataShare.createDataProxyHandle().then((dataProxyHandle) => {
const urisToGet: string[] = [
'datashareproxy://com.samples.shareconfig/config1',
'datashareproxy://com.samples.shareconfig/config2'
];
const config: dataShare.DataProxyConfig = {
type: dataShare.DataProxyType.SHARED_CONFIG,
};
dataProxyHandle.get(urisToGet, config).then((results: dataShare.DataProxyGetResult[]) => {
results.forEach((result) => {
console.info(`URI: ${result.uri}, Result: ${result.result}, AllowList: ${result.allowList}`);
});
}).catch((error: BusinessError) => {
console.error('Error getting config:', error);
});
}).catch((error: BusinessError) => {
console.error('Error creating DataProxyHandle:', error);
});
}

监听/取消监听配置变化

使用on接口监听配置变化,使用off接口取消监听配置变化。

function watchConfigChanges() {
dataShare.createDataProxyHandle().then((dsProxyHelper) => {
const uris: string[] = [
'datashareproxy://com.samples.shareconfig/config1',
'datashareproxy://com.samples.shareconfig/config2'
];
const config: dataShare.DataProxyConfig = {
type: dataShare.DataProxyType.SHARED_CONFIG,
};
const callback = (err: BusinessError<void>, changes: dataShare.DataProxyChangeInfo[]): void => {
if (err) {
console.error('err:', err);
} else {
changes.forEach((change) => {
console.info(`Change Type: ${change.type}, URI: ${change.uri}, Value: ${change.value}`);
});
}
};
// 监听配置变化
const listenResults: dataShare.DataProxyResult[] = dsProxyHelper.on('dataChange', uris, config, callback);
listenResults.forEach((result) => {
console.info(`URI: ${result.uri}, Result: ${result.result}`);
});
// 取消监听配置变化
const unListenResults: dataShare.DataProxyResult[] = dsProxyHelper.off('dataChange', uris, config, callback);
unListenResults.forEach((result) => {
console.info(`URI: ${result.uri}, Result: ${result.result}`);
});
}).catch((error: BusinessError) => {
console.error('Error creating DataProxyHandle:', error);
});
}