华为运动健康服务(HUAWEI Health Kit)提供原子化数据开放,在获取用户对数据的授权后,应用可通过接口访问运动健康数据,对用户数据进行增、删、改、查等操作,为用户提供运动健康类数据服务。这篇文章中我们总结了开发者提出的授权相关的典型问题并给出了参考解决方法,希望为其他遇到类似问题的开发者提供参考。

1. Android App不能唤起Health Kit授权,HealthKitAuthResult result 授权失败statusCode: 6003的原因是什么?

“6003”是HMS Core SDK框架的报错。当证书指纹校验-签名证书指纹错误时,将返回6003错误码。此时,需要按照以下2个步骤检查apk中配置的签名证书是否正确。

步骤1.检查申请相关服务时是否配置了正确的证书指纹。打开应用的APK,将其中“META-INF”文件夹解压出来,得到其中的“CERT.RSA”文件,通过keytool -printcert -file META-INF/CERT.RSA命令打印签名证书信息。

步骤2.登录AppGallery Connect,单击“我的项目”,选择需要操作项目,进入项目页面后选择应用,然后在“项目设置 > 常规”中检查“SHA256证书指纹”配置的信息是否与步骤1的指纹一致。

更多HMS Core SDK框架错误码可参考官网文档

2. 调用接口时返回50005错误码“鉴权未知错误”,是什么原因?

调用端侧接口返回50005错误码,请做如下检查:

(1)授权操作前,请确保你在联盟卡片中申请读/写的运动健康数据的审核已经通过。

(2)应用在拉起授权页面时,展示给用户可选择授权的数据需要包含在联盟卡片审核通过的运动健康数据中。

(3)应用可操作的用户数据为联盟卡片审核通过的数据类型读/写权限与用户在授权页面勾选的数据类型读/写权限的交集。

(4)HMS会对Scope权限信息进行缓存,缓存时长为24小时。如果出现此错误,可能是缓存原因导致。

在手机“应用管理”里清除“HMS Core”的缓存和数据。

在“华为帐号 > 隐私中心 > 控制对您帐号的访问”里取消对App的授权,然后重新打开App登录华为帐号并申请授权。

3. 获取token报20022(invalid direct_uri),一般是什么原因导致的?

错误码20022表示redirect_uri的格式校验没有通过。建议做如下的检查:

(1)使用redirect_uri获取token时,填写的redirect_uri需要与您在申请帐号服务-设置帐号服务信息时,填写在应用的“产品服务>帐号>回调地址”中的填写的一致。

(2)redirect_uri需要经过URLEncode编码。

注意:用户在授权页面同意授权后,OAuth授权服务将响应值授权码Code,通过回调地址redirect_uri返回给应用,此时返回的是URLEncode编码后的授权码,可直接使用。使用Postman 请求时,Body用x-www-form-urlencoded时,code需要先解码再使用,即URLDecode编码;body用raw格式时,code可直接用,不需要解码。

认证鉴权示例参考文档

更多华为帐号REST错误码信息参考文档

4. 我的应用需要获取用户最近一次跑步时的运动时间、热量消耗、配速、平均心率以及步数数据,在Health Kit申请时是否需要申请运动健康数据中的心率数据权限?还是只需申请运动记录数据权限?在代码部分的Scopes又该申请哪些权限?

如果你的应用需要读取运动健康App上运动记录卡片中的数据,首先需要了解运动记录数据开放由两部分权限组成:

(1)运动记录概要数据权限

联盟卡片申请的权限名称:运动记录数据 > 用户运动记录数据

读取运动记录的Scope权限:

Android SDK接入:Scopes.HEALTHKIT_ACTIVITY_RECORD_READ

REST接入:https://www.huawei.com/healthkit/activityrecord.read(Scope权限URL)

以跑步运动记录为例,当你的应用需要获取用户跑步运动记录中的距离统计、卡路里统计、步数统计等采样统计数据类型时,由于采样统计数据类型属于运动记录概要数据中的一部分,只需要申请用户运动记录数据读权限。

(2)运动记录关联的原子采样数据权限

需要每个原子采样数据类型对应的OAuth权限。

以跑步运动记录为例,如果你的应用需要获取跑步运动记录关联的GPS详情、步频详情、海拔的详情等数据,那么还需要每个原子采样数据类型对应的OAuth权限。

原子采样数据类型对应联盟卡片申请的权限名称、Scope权限请参见联盟文档的数据类型章节:Android SDK接入 REST接入

了解更多详情>>

访问华为运动健康服务联盟官网

访问华为开发者联盟官网

获取开发指导文档

华为移动服务开源仓库地址:GitHubGitee

关注我们,第一时间了解 HMS Core 最新技术资讯~

【FAQ】申请华为运动健康服务授权的4个常见问题及解决方法的更多相关文章

  1. Mate 40系列发布 搭载华为运动健康服务带来健康数字生活

    10月30日,HUAWEI Mate 40系列国内发布会如期而至.Mate 40系列除了拥有强悍的性能.全能记录影像和突破性的交互之外,还搭载了全新升级的HMS Core,其中,Health Kit( ...

  2. 【FAQ】运动健康服务REST API接口使用过程中常见问题和解决方法总结

    华为运动健康服务(HUAWEI Health Kit)为三方生态应用提供了REST API接口,通过其接口可访问数据库,为用户提供运动健康类数据服务.在实际的集成过程中,开发者们可能会遇到各种问题,这 ...

  3. PHP实现开发者模式出现该公众号提供的服务出现故障 请稍后再试解决方法

    PHP实现开发者模式出现该公众号提供的服务出现故障 请稍后再试解决方法 仔细检查下有没有echo等输出的代码  echo没有输出东西 就是报这个信息  所以调试信息都必须写入日记

  4. 【FAQ】华为帐号服务报错 907135701的常见原因总结和解决方法

    很多开发者在接入华为帐号服务时,经常会出现907135701的报错.根据官网文档说明,错误码907135701表示: 这个错误码在安卓和鸿蒙上都会出现,导致该报错的原因有很多,开发者可以按照下面几点进 ...

  5. 【FAQ】应用集成HMS Core部分服务出现“ 6003报错”情况的解决方法来啦

    背景 开发者在应用中集成HMS Core部分服务时,android sdk 以及flutter等跨平台sdk,会出现编译打包后,运行报6003错误码的情况.根据查询可以得知,错误代码 6003 表示证 ...

  6. 阿里云配置ssl证书服务遇到的几个问题和解决方法

    系统环境: 系统:阿里云ECS CentOS6.5+Apache2.4.10 前提:公司需要将站点升级到使用SSL证书服务(https) 实践执行:在阿里云的证书服务--选择了一个免费的证书服务,毕竟 ...

  7. Ubuntu Server安装telnet服务时"Unable to locate package telnetd"解决方法

    装好Ubuntu Server 12.04后,用apt-get安装telnetd报"E: Unable to locate package telnetd",解决方法如下: 虚拟机 ...

  8. Win2008服务启动不能调用Office Word的解决方法

    本文为大家分享一下如何解决Windows Server 2008 服务启动不能调用Office Word的问题,分享这个教程的原因是,今天在Windows server2008上部署一个应用时发现了一 ...

  9. eclipse启动Tomcat服务输入http://localhost:8080/报404解决方法

    其实如果Tomcat能够正常启动,而就算输入http://localhost:8080时出现404错误,也不会影响Tomcat作为服务器运行.通过eclipse来启动tomcat会碰到“访问http: ...

随机推荐

  1. Effective Java —— 消除过期的对象引用

    本文参考 本篇文章参考自<Effective Java>第三版第七条"Eliminate obsolete object references" Memory leak ...

  2. 攻防世界PHP2

    PHP2 进入环境就一个英文其他啥都没有,英文也没啥提示信息 我们使用dirsearch扫描一下,一开始确实没扫到什么东西,到最后看了wp发现原来源码是在index.phps中,这里只提供一个思路,不 ...

  3. 领域驱动(DDD)设计和开发实战

    领域驱动设计(DDD)的中心内容是如何将业务领域概念映射到软件工件中.大部分关于此主题的著作和文章都以 Eric Evans 的书<领域驱动设计>为基础,主要从概念和设计的角度探讨领域建模 ...

  4. c++中的printf、和cout和cin后面跟指针的问题

    printf里面打印指针的问题 而在c语言中,使用printf只需要使用不同的格式就可以区分打印出是字符串还是指针变量的值: cout和cin后面跟指针的问题 cout<<mm 和cin& ...

  5. VC 下如何正确的创建及管理项目

    讲解 VC 下如何正确的创建及管理项目 本文讲解 Visual C++ 的项目文件组成,以及如何正确的创建及管理项目. 本文所设计的内容是初学者必须要掌握的.不能正确的管理项目,就不能进一步写有规模的 ...

  6. 「入门篇」初识JVM (下下) - GC

    垃圾收集主要是针对堆和方法区进行:程序计数器.虚拟机栈和本地方法栈这三个区域属于线程私有的,只存在于> 线程的生命周期内,线程结束之后也会消失,因此不需要对这三个区域进行垃圾回收. GC - J ...

  7. HTML中meta标签详解;property=og标签详解

    meta是用来在HTML文档中模拟HTTP协议的响应头报文.META标签是HTML语言HEAD区的一个辅助性标签,它位于HTML文档头部的<HEAD>标记和<TITLE>标记之 ...

  8. 如何跨线程访问Winform中的UI元素

    如何跨线程访问Winform中的UI元素 假如制作一个Socket聊天应用程序,很可能会用到多线程: 例如为Receive方法开辟单独一个线程,例如为Receive方法开辟单独一个线程(后台运行的线程 ...

  9. 惠普电脑win10系统中WLAN不见了

    原文链接:笔记本电脑win10系统中WLAN不见了 怎么解决? - 知乎 (zhihu.com)

  10. java中接口和抽象类有什么区别,举例!

    2)接口和抽象类有什么区别?答:马克-to-win:抽象类里可以有实现的方法,接口里不能有,所以相对来讲各方面实现都简单(尤其动态方法调度).另外:类可以实现多个接口.反过来说,也正是抽象类一个致命伤 ...