[HarmonyOS Next示例代码] 鸿蒙功能开发 - 华为账号服务

用户云卷云舒  金牌会员 | 2024-9-14 06:33:56 | 来自手机 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 849|帖子 849|积分 2547

 鸿蒙功能开发 - 华为账号服务 源码下载地址
介绍

本示例展示了使用 Account Kit 提供的登录、授权头像昵称、快速验证手机号、收货地址、发票仰面、未成年人模式的能力。
本示例模拟了在应用里,调用一键登录 Button 组件拉起符合华为规范的登录页面;调用登录接口实现静默登录;调用获取头像昵称接口获取头像昵称;调用快速验证手机号接口拉起号快速验证页面;调用收货地址接口获取收货地址;调用发票仰面接口获取发票仰面;调用未成年人模式接口开启或关闭未成年人模式;订阅未成年人模式公共变乱;调用未成年人模式验密接口验证未成年人模式暗码。
需要使用 Account Kit 接口 @kit.AccountKit
结果预览

登录/注册页面一键登录组件登录页面一键登录组件弹窗页面

  

  

  应用其他登录页用户登录后首页用户个人信息页面

  

  

  头像昵称授权页获取快速验证手机号页面获取收货地址页面

  

  

  开启未成年人模式页面关闭未成年人模式页面

  

  本示例的配置与使用

在DevEco中配置本示例的步骤如下


  • 创建项目及应用。
  • 在华为开发者同盟为应用配置权限(权限名:phone、quickLoginMobilePhone),详细操作可参考Account Kit开发指南。
  • 应用调用收货地址API前,需完成对应的权限申请,当前可通过accountkit@huawei.com举行邮件申请。请提供如下信息举行申请,我们会在5个工作日内回复申请结果,请您留意邮箱信息。
    邮箱主题:【获取收货地址】权限申请
    邮件正文:***
    企业名称:***
    应用名称:***
    应用包名:com.***.***
    APP ID: 1****12
    Client ID:1****14
    使用场景:***
  • 打开本示例,使用AppGallery Connect配置的应用包名替换app.json5文件中的bundleName属性值。
  • 使用AppGallery Connect配置的应用Client ID替换module.json5文件中的client_id属性值。
  • 天生SHA256应用签名证书指纹并添加到AppGallery Connect对应的应用配置中,证书指纹天生请参考应用开发准备中的添加公钥指纹章节。
本示例使用说明


  • 运行本示例,依次点击“登录/注册”和“华为账号一键登录”按钮举行登录,如果体系账号未登录,会拉起应用其他登录方式。
  • 如体系已登录注册地为中国大陆且已绑定手机号的华为账号,应用在申请完“华为账号一键登录”权限后,点击“登录/注册”按钮,会拉起嵌有“华为账号一键登录”按钮的登录页面,否则拉起其他登录方式,其他登录方式仅为演示,现实并未登录成功。
  • 登录成功后,在应用首页点击“酷爱的用户”会进入个人信息页面,如果头像昵称未授权,点击酷爱的用户或默认头像会拉起头像昵称授权页面,授权成功后会在个人信息页展示华为账号头像昵称。个人信息页面的头像、昵称仅用于展示,不可点击修改。
  • 申请 phone 权限后,在个人信息页点击手机号,会拉起手机号验证及授权页面,授权成功后展示匿名手机号或 180******00(本示例只获取 code,获取 code 后需要将 code 传给应用服务器,调用华为账号服务器接口换取 Access Token,然后再获取用户手机号),如未申请权限则点击无效。
  • 申请获取收货地址 API 权限后,在个人信息页点击收货地址拉起选择收货地址页面,用户选择对应的地址后展示收货地址信息。
  • 在个人信息页点击发票仰面拉起选择发票仰面页面,用户选择对应的仰面后展示发票仰面信息。
  • 在个人信息页,点击未成年人模式开关,引导用户开启或关闭未成年人模式,未成年人模式开启时,可用时长限定开关默认为开启状态,用户可以点击可用时长限定开关,关闭时长限定,当可用时长限定为关闭状态时,用户也可点击可用时长限定开关开启时长限定。当前应用启动后会订阅未成年人模式开启/关闭变乱,当感知到体系未成年人模式开启/关闭时,则应用未成年人模式开关状态会跟随体系未成年人模式状态举行切换。
  • 在个人信息页,点击使用华为账号静默登录开关,会开启或关闭静默登录功能,开启静默登录后,不管用户是否退出登录应用,下次重新打开应用都会通过华为账号静默登录应用。
  • 在个人信息页面,点击退出登录按钮后,修改用户登录状态为未登录并返回首页。
  • 应用启动时,会调用 getMinorsProtectionInfoSync 接口,查询未成年人模式的开启状态,并且获取存储在PersistentStorage里的应用的未成年人模式状态(PersistentStorage模拟应用持久化存储未成年人模式状态)。

    • 当从PersistentStorage取到应用未成年人模式处于关闭状态,查询到体系未成年人模式已开启,则弹出"未成年人模式已开启"。
    • 当从PersistentStorage取到应用未成年人模式处于开启状态,查询到体系未成年人模式已关闭,则弹出"未成年人模式已关闭"。
    • 当从PersistentStorage取到应用未成年人模式状态和查询到的体系未成年人模式状态同等时,则不做出提示,应用维持现有逻辑。

  • 当未成年人模式开启时,当前设备的开发者调试模式会被禁用,开发者可以进入设置-体系-开发者选项,点击USB调试开关,会校验康健使用手机暗码,校验成功后可解除开发者调试模式限定。
工程目录

  1. ├─entry/src/main/ets            // 代码区
  2. │ ├─common                      // 公用代码
  3. │ │ └─AvoidRepeatClick.ets      // 防止重复点击工具类
  4. │ │ └─CommonEventUtil.ets       // 公共类,包含监听未成年人状态变化的事件
  5. │ │ └─ErrorCodeEntity.ets       // 登录过程中可能遇到的错误码信息页面
  6. │ │ └─UserInfo.ets              // 用户信息数据结构
  7. │ │ └─Utils.ets                 // 公用的一些业务方法
  8. │ ├─components                  // 存放组件文件目录
  9. │ │ └─Address.ets               // 获取收货地址组件
  10. │ │ └─AgreementDialog.ets       // 隐私协议弹窗组件
  11. │ │ └─AvatarAndNickname.ets     // 获取头像、昵称组件
  12. │ │ └─InvoiceTitle.ets          // 获取发票抬头组件
  13. │ │ └─MinorsProtection.ets      // 开启、关闭未成年人模式组件
  14. │ │ └─Phone.ets                 // 手机号授权组件
  15. │ │ └─SilentlyLoginSwitch.ets   // 开启、关闭静默登录组件
  16. │ │ └─UserAgreement.ets         // 用户协议组件
  17. │ ├─entryability
  18. │ │ └─EntryAbility.ets          // 程序入口类
  19. │ ├─pages                       // 存放页面文件目录
  20. │ │ └─HomePage.ets              // 主页面,作为Navigation跳转的容器
  21. │ │ └─OtherLoginPage.ets        // 应用自定义的其他登录方式
  22. │ │ └─PersonalInfoPage.ets      // 个人信息页,包含头像、昵称、默认手机号展示,同时包含快速验证手机号授权、获取收货地址、设置未成年人模式、获取发票抬头、使用华为账号静默登录场景
  23. │ │ └─PrepareLoginPage.ets      // 首页内容,包括获取匿名手机号、未成年人模式的开启状态场景
  24. │ │ └─ProtocolWebView.ets       // 华为账号用户认证协议页面
  25. │ │ └─QuickLoginPage.ets        // 华为账号一键登录组件,包含组件调用
  26. └──entry/src/main/resources     // 资源文件目录
复制代码
详细实现

调用一键登录组件拉起符合华为规范的登录页面,参考QuickLoginPage.ets:


  • 使用 loginComponentManager.PrivacyText 创建 QuickLoginPage 组件隐私文本对象 privacyText
  • 使用 loginComponentManager.LoginWithHuaweiIDButtonController 构造 QuickLoginPage 组件的控制器对象 controller
  • 创建一键登录组件对象将 privacyText、controller 等作为参数传入,拉起登录界面
  • 使用 setAgreementStatus 方法设置用户是否同意协议,通过该状态判断是否需要拉起协议弹窗
  • 使用 continueLogin 方法设置同意协议与登录一同完成,同意协议后直打仗发登录的异步回调,用户无需再次点击登录按钮
  • 通过 LoginWithHuaweiIDButton 组件内设置 param 中的 extraStyle 属性开启一键登录按钮的点击加载态
调用获取头像昵称授权接口拉起授权页面、调用快速验证手机号接口完成手机号快速验证与授权、调用收货地址接口获取收货地址信息、调用发票仰面接口获取发票仰面信息、调用未成年人模式相关接口设置未成年人模式,参考 PersonalInfoPage.ets:


  • 使用 authentication.HuaweiIDProvider().createAuthorizationWithHuaweiIDRequest() 创建授权请求,完成头像昵称参数设置
  • 使用 authentication.AuthenticationController(getContext(this)) 创建 controller
  • 调用 controller.executeRequest() 实行请求
  • 使用 authentication.HuaweiIDProvider().createAuthorizationWithHuaweiIDRequest() 创建授权请求,完成快速验证手机号参数设置
  • 使用 authentication.AuthenticationController(getContext(this)) 创建 controller
  • 调用 controller.executeRequest() 实行请求
  • 使用 shippingAddress.chooseAddress 获取 AddressInfo 对象
  • 从 AddressInfo 对象中获取收货人姓名、电话、地址信息
  • 使用 invoiceAssistant.selectInvoiceTitle 获取 InvoiceTitle 对象
  • 从 InvoiceTitle 对象中获取发票仰面名称、税号等信息
  • 使用 minorsProtection.leadToTurnOnMinorsMode 引导用户开启未成年人模式,应用内提供入口,帮助用户快速开启未成年人模式
  • 使用 minorsProtection.leadToTurnOffMinorsMode 引导用户关闭未成年人模式,应用内提供入口,帮助用户快速关闭未成年人模式
  • 使用 minorsProtection.verifyMinorsProtectionCredential 校验用户开启未成年人模式的暗码,防止未成年人更改体系未成年人模式设置
使用 HomePage 作为 Navigation 容器举行页面承载,参考 HomePage.ets:


  • 使用 new authentication.HuaweiIDProvider().createLoginWithHuaweiIDRequest() 创建静默登录请求,配合 PersistentStorage 模拟静默登录
PrepareLoginPage 作为应用首页调用未成年人模式接口,参考 PrepareLoginPage.ets:


  • 使用 PersistentStorage和AppStorage 存储和获取到当前应用是否开启未成年人模式的状态
  • 调用 minorsProtection.getMinorsProtectionInfoSync() 函数,从 minorsProtection.MinorsProtectionInfo 对象中获取未成年人模式的开启状态,应用可以跟随体系未成年人模式举行打开自己的未成年人模式
在 CommonEventUtil 监听未成年状态变化,参考在CommonEventUtil.ets:


  • 使用 @ohos.commonEventManager 体系能力监听 COMMON_EVENT_MINORSMODE_ON 和 COMMON_EVENT_MINORSMODE_OFF 变乱,当应用进程存在时,应用可以实时感知到体系未成年人模式的变化,从而与体系联动改变自己的未成年人模式
在 OtherLoginPage页面中自定义用户的其他登录方式:


  • 比如手机号验证码、暗码等
在 ProtocolWebView 页面中使用Web组件体现《华为账号用户认证协议》内容:


  • 在 data.json 中获取网页链接,当前仅支持中英文
在 AgreementDialog 中实现用户隐私协议的弹窗组件


  • 通过自定义 CustomDialogController 控制弹窗的显隐
在 ErrorCodeEntity 中定义通用的实体数据信息


  • 比如通用错误码、通用常量等
在 UserInfo 中定义 UserInfo 的数据结构
在 EntryAbility 中订阅未成年人模式公共变乱
在 AvoidRepeatClick 类中实现防止用户短时间内重复点击方法
参考

  • entry\src\main\ets\pages\QuickLoginPage.ets
  • entry\src\main\ets\pages\PersonalInfoPage.ets
  • entry\src\main\ets\common\CommonEventUtil.ets
  • entry\src\main\ets\pages\HomePage.ets
  • entry\src\main\ets\pages\PrepareLoginPage.ets
  • entry\src\main\ets\pages\OtherLoginPage.ets
  • entry\src\main\ets\pages\ProtocolWebView.ets
  • entry\src\main\ets\components\AgreementDialog.ets
  • entry\src\main\ets\common\ErrorCodeEntity.ets
  • entry\src\main\ets\common\UserInfo.ets
  • entry\src\main\ets\entryability\EntryAbility.ets
  • entry\src\main\ets\common\AvoidRepeatClick.ets
相关权限


  • 本示例在调用一键登录组件和获取头像昵称授权等场景需要访问网络,已在 module.json5 文件中添加网络权限" ohos.permission.INTERNET"。
  • 本示例在跳转网页前需要查询网络毗连状态,已在 module.json5 文件中添加网络权限" ohos.permission.GET_NETWORK_INFO"。
依赖

依赖设备具备 WIFI 能力

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

用户云卷云舒

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表