【FAQ】HarmonyOS鸿蒙Next SDK 闭源开放能力 —Health Service Kit
【FAQ】HarmonyOS鸿蒙Next SDK 闭源开放能力 —Health Service Kit
- 问题描述:
- 按照官方文档调用healthStore API申请用户授权;有拉起授权弹窗,但是无回调,检查权限接口也无回调。
解决方案:
-
接口调用前,需先使用init方法进行初始化,没有回调的问题请确认是否已调用init方法。
-
步数通过日常活动数据进行开放,如果需要获取步数数据,需要申请“日常活动数据”权限。
-
应用也可以参考官方实例代码:
-
问题描述:
- DailyActivities日常活动采样数据字段列表。怎么利用这个接口获取用户的步数?
解决方案:
-
获取步数需要先在Health Service Kit联盟卡片中申请日常活动采样数据权限,权限说明见:
-
权限申请通过后,在用户授权的前提下,可以通过以下接口获取步数数据:
-
接口调用示例可以参考sampleCode:
-
问题描述:
- 申请了健康运动权限,但是在授权
healthStore.samplePointHelper.dailyActivities.DATA_TYPE
已经授权过了,但是在查询这个权限还是查询不到,目前申请的权限不知道是不是这个权限。
- 申请了健康运动权限,但是在授权
解决方案:
-
根据AppID:109912713查询,权限是已经申请了的。
-
请检查
module.json5
中配置的client_id
是否为:109912713。- 路径见“配置Client ID指南”:
-
先调用“取消授权接口”取消授权后,再调用用户授权接口,重新进行用户授权,在授权时请确认是否有添加
healthStore.samplePointHelper.dailyActivities.DATA_TYPE
权限; -
用户勾选权限并授权后,重新调用查询授权接口看看;
- 查询权限:
-
如果问题依旧存在,请提供未做筛选的详细日志,可以执行以下命令获取:
- 执行:
hdc hilog > xxxx.log
- 触发定位
- 停止脚本执行。
- 在目录下获取日志信息。
- 补充:调用“取消授权接口”是为了刷新权限缓存,此问题可能是缓存原因导致的;
- 执行:
-
问题描述:
- 健康权限申请权限授权后查询不到相关权限
- 已经申请过健康运动权限,在应用授权
readDataTypes: [healthStore.exerciseSequenceHelper.DATA_TYPE]
,出现相关弹窗后确定再去调用查询权限api,但是查询的结果是空的,想问下是不是我们当前应用readDataTypes: [healthStore.exerciseSequenceHelper.DATA_TYPE]
是否申请成功?
解决方案:
-
原因分析:
- 查询权限接口,只有在应用已申请,且用户已授权的情况下,才会返回结果。
healthStore.exerciseSequenceHelper.DATA_TYPE
是锻炼记录,当前应用未申请锻炼记录权限,故查询锻炼记录权限时无结果值返回;
-
处理建议:
- 请检查
module.json5
文件中配置的client_id
,是否有在联盟卡片中申请锻炼记录权限; - 配置的
client_id
位置信息,请查看“配置Client ID”指南: - 如果需要使用锻炼记录权限,请在联盟卡片中为当前应用申请锻炼记录权限,申请指南请见“申请运动健康服务”指南:
- 如果开发者需要使用并授权日常活动数据权限,应使用日常活动权限:
samplePointHelper.dailyActivities.DATA_TYPE
- 详见权限说明:
- 日常活动数据权限可以查询用户步数信息,在用户授权的前提下,可以通过以下接口获取步数数据:
- 通过
healthStore.readData
接口获取步数明细数据(数据及时性:10分钟级); - 通过
healthStore.aggregateData
接口获取步数统计数据(数据及时性:10分钟级); - 通过
workout.readActivityReport
读取实时三环数据接口,查询实时的步数数据; - 接口调用示例可以参考此sampleCode:
- 通过
- 请检查
-
问题描述:
- 运动与健康这里调用
workout.readActivityReport
这个api去获取运动数据的时候,用刚注册的华为账号或者这个账号不在应用指纹里调用这个接口会报一个201的错误,用之前的添加到应用指纹的华为账号是可以的,这种在线上正式包的时候也会出现这个错误
- 运动与健康这里调用
解决方案:
- 调用
readActivityReport
接口前,需要完成以下步骤:- 完成申请运动健康服务与配置Client ID。
- 需先通过用户授权接口引导用户授权,用户授权日常活动数据类型读权限(参考权限说明)后,才有权限读取实时三环数据。
- 详见“读取实时三环数据”指南:
- 错误码201是鉴权失败。
- 可能原因
- 应用指纹配置不正确。
- 缺少权限。
- 部分接口仅白名单用户可调用。
- 测试用户数已达上限。
- 处理步骤
- 检查AGC上应用的指纹证书,详情请见添加公钥指纹。
- 参考管理用户授权,确认用户已授权相关权限。
- 用户申请成为测试用户失败,请尽快参考申请验证获取正式权限,完成管理台应用验收。
- 详见“201 鉴权失败”:
- 可能原因
更多关于【FAQ】HarmonyOS鸿蒙Next SDK 闭源开放能力 —Health Service Kit的实战教程也可以访问 https://www.itying.com/category-93-b0.html
更多关于【FAQ】HarmonyOS鸿蒙Next SDK 闭源开放能力 —Health Service Kit的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html
HarmonyOS鸿蒙Next SDK中的Health Service Kit提供了一套闭源开放能力,旨在支持开发者构建健康相关的应用。该Kit集成了多种健康数据采集与分析功能,如步数、心率、睡眠监测等,帮助开发者快速接入设备健康数据。通过Health Service Kit,开发者可以高效地开发健康管理应用,提升用户体验,同时确保数据的安全与隐私。该Kit适用于智能手表、手环等可穿戴设备,助力健康生态的构建与扩展。