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

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

相关文章

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

usaco 1.2 Transformations(模拟)

我的做法就是一个一个情况枚举出来 注意计算公式: ( 变换后的矩阵记为C) 顺时针旋转90°:C[i] [j]=A[n-j-1] [i] (旋转180°和270° 可以多转几个九十度来推) 对称:C[i] [n-j-1]=A[i] [j] 代码有点长 。。。 /*ID: who jayLANG: C++TASK: transform*/#include<

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

hdu4431麻将模拟

给13张牌。问增加哪些牌可以胡牌。 胡牌有以下几种情况: 1、一个对子 + 4组 3个相同的牌或者顺子。 2、7个不同的对子。 3、13幺 贪心的思想: 对于某张牌>=3个,先减去3个相同,再组合顺子。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOExcepti

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数