模拟登录页,华为账号一键登录

2024-08-30 02:12

本文主要是介绍模拟登录页,华为账号一键登录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、介绍
基于鸿蒙Next模拟账号一键登录,免去账号注册环节
二、场景需求
1. 用户场景
新用户: 需要快速注册并登录,以体验华为的服务。
老用户: 希望快速登录,不用每次输入用户名和密码。
2. 界面设计
Logo和标题: 页面顶部展示华为的Logo及"一键登录"或"华为账号登录"的标题。
3. 功能需求:短信/邮箱验证码:
4. 安全性
二次验证: 可选启用二次验证,如在高风险环境下(新设备登录等),要求用户通过邮件或短信进行确认。
5. 适应性
响应式设计: 确保在不同设备(手机、平板、电脑)上的良好展示。
多语言支持: 提供多种语言选项,方便不同地区用户使用。
6. 用户反馈
操作反馈: 无论是按钮点击还是输入错误,都需要及时反馈用户操作状态。
常见问题解答链接: 用户如果在登录时遇到问题,可以快速找到帮助。

三、业务步骤
第一步:点击“一键登录”,获取登录信息
第二步:拉起授权弹窗
第三步:获取授权,获取用户信息
第四步:展示用户信息,显示功能选项
四、效果展示
 

#HarmonyOS NEXT 体验官#模拟登录页,华为账号一键登录-鸿蒙开发者社区


五:代码展示:

import { authentication } from '@kit.AccountKit';
import { hilog } from '@kit.PerformanceAnalysisKit';
import { util } from '@kit.ArkTS';
import { BusinessError } from '@kit.BasicServicesKit';//自定义
import { Mine_SystemItem_Type,CommonConstants } from "../common/CommonConstant"@Entry
@Component
struct Index06 {@State tabMineItem:Mine_SystemItem_Type[] = CommonConstants.MINE_SYSTEM_ITEM_LIST@State isLogin: boolean = false@State userImg: string|Resource|undefined = $r("app.media.app_icon") // 登录头像@State userName: string|undefined = '昵称001' // 用户昵称@State btnTitle: string = '华为账号一键登录' // 用户昵称getHuaWeiAccount(){// 创建授权请求,并设置参数let authRequest = new authentication.HuaweiIDProvider().createAuthorizationWithHuaweiIDRequest();// 获取头像昵称需要传如下scopeauthRequest.scopes = ['profile','phone'];// 若开发者需要进行服务端开发,则需传如下permission获取authorizationCodeauthRequest.permissions = ['serviceauthcode'];// 用户是否需要登录授权,该值为true且用户未登录或未授权时,会拉起用户登录或授权页面authRequest.forceAuthorization = true;// 用于防跨站点请求伪造。authRequest.state = util.generateRandomUUID();// 执行授权请求try {let controller = new authentication.AuthenticationController(getContext(this));controller.executeRequest(authRequest).then((data) => {let authorizationWithHuaweiIDResponse = data as authentication.AuthorizationWithHuaweiIDResponse;let state = authorizationWithHuaweiIDResponse.state;if (state != undefined && authRequest.state != state) {hilog.error(0x0000, 'testTag', `Failed to authorize. The state is different, response state: ${state}`);return;}hilog.info(0x0000, 'testTag', 'Succeeded in authentication: %{public}s',JSON.stringify(authorizationWithHuaweiIDResponse));this.isLogin = !this.isLoginthis.btnTitle = '退出'this.userImg = authorizationWithHuaweiIDResponse.data!.avatarUri;this.userName = authorizationWithHuaweiIDResponse.data!.nickName;}).catch((err: BusinessError) => {this.dealAllError(err);});} catch (error) {this.dealAllError(error);}}// 错误处理dealAllError(error: BusinessError): void {hilog.error(0x0000, 'testTag', `Failed to auth. Code: ${error.code}, message: ${error.message}`);}build() {Column() {Column() {//头像Column() {Image(this.userImg).objectFit(ImageFit.Cover).height(72).width(72).borderRadius(36)Row().height(20)Text(this.userName).fontSize(16)}.width('90%').borderRadius(12).alignItems(HorizontalAlign.Center).justifyContent(FlexAlign.Center).backgroundColor(0xFFFFFF).shadow({radius: 10,color: "#dddddd",offsetX: 6,offsetY: 6}).margin({ top: 15, bottom: 10 }).padding({ top: 30, bottom: 30 })}.justifyContent(FlexAlign.Start).alignItems(HorizontalAlign.Center)Button(this.btnTitle).width('70%').height(30).onClick(()=>{this.getHuaWeiAccount()// this.isLogin = !this.isLogin// this.btnTitle = '退出'}).margin({ top:10,bottom:20 })if (this.isLogin){Column(){//功能选项ForEach(this.tabMineItem,(item:Mine_SystemItem_Type,index:number)=>{Row(){Text(item.itemTitle).fontSize(16).fontColor(0x161616)Blank()Image($r("app.media.ic_right_back_greyWhite")).width(24).height(24)}.width('100%').height(48).padding({left:15,right:10}).stateStyles({normal:{.backgroundColor(0xFFFFFF)},pressed:{.backgroundColor(0xEFEFEF)}})},(item:string)=>item)Row(){Text('隐私声明').fontSize(16).fontColor(0x161616)Blank()Image($r("app.media.ic_right_back_greyWhite")).width(24).height(24)}.width('100%').height(48).padding({left:15,right:10}).stateStyles({normal:{.backgroundColor(0xFFFFFF)},pressed:{.backgroundColor(0xEFEFEF)}})}.width('90%').justifyContent(FlexAlign.Start).alignItems(HorizontalAlign.Center).backgroundColor(0xFFFFFF).shadow({radius:10,color:"#dddddd",offsetX:6,offsetY:6}).padding({top:10,bottom:10}).borderRadius(12)}}.width('100%').height('100%').justifyContent(FlexAlign.Start).backgroundColor(0xEEEEEE)}}

这篇关于模拟登录页,华为账号一键登录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1119504

相关文章

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

SpringSecurity显示用户账号已被锁定的原因及解决方案

《SpringSecurity显示用户账号已被锁定的原因及解决方案》SpringSecurity中用户账号被锁定问题源于UserDetails接口方法返回值错误,解决方案是修正isAccountNon... 目录SpringSecurity显示用户账号已被锁定的解决方案1.问题出现前的工作2.问题出现原因各

华为鸿蒙HarmonyOS 5.1官宣7月开启升级! 首批支持名单公布

《华为鸿蒙HarmonyOS5.1官宣7月开启升级!首批支持名单公布》在刚刚结束的华为Pura80系列及全场景新品发布会上,除了众多新品的发布,还有一个消息也点燃了所有鸿蒙用户的期待,那就是Ha... 在今日的华为 Pura 80 系列及全场景新品发布会上,华为宣布鸿蒙 HarmonyOS 5.1 将于 7

Java中的登录技术保姆级详细教程

《Java中的登录技术保姆级详细教程》:本文主要介绍Java中登录技术保姆级详细教程的相关资料,在Java中我们可以使用各种技术和框架来实现这些功能,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录1.登录思路2.登录标记1.会话技术2.会话跟踪1.Cookie技术2.Session技术3.令牌技

Python实现一键PDF转Word(附完整代码及详细步骤)

《Python实现一键PDF转Word(附完整代码及详细步骤)》pdf2docx是一个基于Python的第三方库,专门用于将PDF文件转换为可编辑的Word文档,下面我们就来看看如何通过pdf2doc... 目录引言:为什么需要PDF转Word一、pdf2docx介绍1. pdf2docx 是什么2. by

Python使用pynput模拟实现键盘自动输入工具

《Python使用pynput模拟实现键盘自动输入工具》在日常办公和软件开发中,我们经常需要处理大量重复的文本输入工作,所以本文就来和大家介绍一款使用Python的PyQt5库结合pynput键盘控制... 目录概述:当自动化遇上可视化功能全景图核心功能矩阵技术栈深度效果展示使用教程四步操作指南核心代码解析

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5

SpringBoot后端实现小程序微信登录功能实现

《SpringBoot后端实现小程序微信登录功能实现》微信小程序登录是开发者通过微信提供的身份验证机制,获取用户唯一标识(openid)和会话密钥(session_key)的过程,这篇文章给大家介绍S... 目录SpringBoot实现微信小程序登录简介SpringBoot后端实现微信登录SpringBoo

PyQt5+Python-docx实现一键生成测试报告

《PyQt5+Python-docx实现一键生成测试报告》作为一名测试工程师,你是否经历过手动填写测试报告的痛苦,本文将用Python的PyQt5和python-docx库,打造一款测试报告一键生成工... 目录引言工具功能亮点工具设计思路1. 界面设计:PyQt5实现数据输入2. 文档生成:python-

Android实现一键录屏功能(附源码)

《Android实现一键录屏功能(附源码)》在Android5.0及以上版本,系统提供了MediaProjectionAPI,允许应用在用户授权下录制屏幕内容并输出到视频文件,所以本文将基于此实现一个... 目录一、项目介绍二、相关技术与原理三、系统权限与用户授权四、项目架构与流程五、环境配置与依赖六、完整