news 2026/6/10 13:37:38

HarmonyOS 教学实战(四):登录系统与全局状态管理(像正式 App 一样思考)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
HarmonyOS 教学实战(四):登录系统与全局状态管理(像正式 App 一样思考)

如果一个应用没有登录系统,它大概率只是个 Demo。

从这一篇开始,我们的「任务清单 App」正式进入“产品级应用”阶段


一、真实 App 的登录系统需要解决哪些问题?

很多人写登录,只写了一个页面和一个接口调用,但真实情况远比这复杂:

我们至少要解决👇

  1. 用户是否已登录?
  2. Token 存在哪里?
  3. App 重启是否自动登录?
  4. 多个页面如何共享登录态?
  5. 退出登录如何清理状态?
  6. Token 过期如何处理?

👉 这些问题的答案,都指向:全局状态管理


二、设计登录系统的整体架构(先别写代码)

推荐结构

entry/ ├─ model/ │ ├─ AuthModel.ets // 登录状态模型(全局) │ └─ TaskModel.ets ├─ service/ │ ├─ AuthService.ets // 登录 / 退出 / 刷新 token │ └─ TaskService.ets ├─ store/ │ └─ AppStore.ets // 全局状态入口 ├─ pages/ │ ├─ Login.ets │ └─ Index.ets

📌不要把登录状态写在某个页面里
📌登录态是全局状态


三、第一步:定义登录状态模型(AuthModel)

model/AuthModel.ets

@ObservedV2exportclassAuthModel{token:string=''userName:string=''isLogin:boolean=falselogin(token:string,userName:string){this.token=tokenthis.userName=userNamethis.isLogin=true}logout(){this.token=''this.userName=''this.isLogin=false}}

教学重点

  • 登录状态 =数据模型
  • UI 不直接维护登录变量

四、第二步:封装登录服务(网络 + 存储)

service/AuthService.ets

importpreferencesfrom'@ohos.data.preferences'importhttpfrom'@ohos.net.http'constTOKEN_KEY='USER_TOKEN'constUSER_KEY='USER_NAME'exportclassAuthService{staticasynclogin(account:string,password:string){consthttpRequest=http.createHttp()constresponse=awaithttpRequest.request('https://example.com/api/login',{method:http.RequestMethod.POST,extraData:{account,password}})constresult=JSON.parse(response.resultasstring)return{token:result.token,userName:result.userName}}staticasyncsaveAuth(token:string,userName:string){constpref=awaitpreferences.getPreferences(getContext(),'auth')awaitpref.put(TOKEN_KEY,token)awaitpref.put(USER_KEY,userName)awaitpref.flush()}staticasyncloadAuth(){constpref=awaitpreferences.getPreferences(getContext(),'auth')consttoken=awaitpref.get(TOKEN_KEY,'')constuserName=awaitpref.get(USER_KEY,'')return{token,userName}}staticasyncclearAuth(){constpref=awaitpreferences.getPreferences(getContext(),'auth')awaitpref.clear()awaitpref.flush()}}

📌 网络、缓存全部在 Service 层
📌 Model 不关心存储细节


五、第三步:全局状态 Store(AppStore)

这是整篇的核心设计

store/AppStore.ets

import{AuthModel}from'../model/AuthModel'import{AuthService}from'../service/AuthService'@ObservedV2exportclassAppStore{auth=newAuthModel()loading:boolean=trueasyncinit(){const{token,userName}=awaitAuthService.loadAuth()if(token){this.auth.login(token,userName)}this.loading=false}asynclogin(account:string,password:string){constresult=awaitAuthService.login(account,password)this.auth.login(result.token,result.userName)awaitAuthService.saveAuth(result.token,result.userName)}asynclogout(){this.auth.logout()awaitAuthService.clearAuth()}}

教学重点(非常重要)

  • App 启动时只初始化一次
  • 所有页面共享同一个 AppStore
  • 登录 / 退出是统一入口

六、第四步:将 AppStore 变成“全局状态”

使用@Provider / @Consume

App 根组件(如 Entry)

@ComponentV2 struct AppRoot{@Local store=newAppStore()@Onceasyncinit(){awaitthis.store.init()}build(){if(this.store.loading){Text("初始化中...")}else{if(this.store.auth.isLogin){Index()}else{Login()}}}}

提供全局状态

@Provider appStore:AppStore=this.store

任意页面获取登录态

@Consume appStore:AppStoreText(`你好,${this.appStore.auth.userName}`)

📌 这就是HarmonyOS 的全局状态管理方式


七、第五步:登录页面实现

pages/Login.ets

@ComponentV2 struct Login{@Consume appStore:AppStore @Local account:string=''@Local password:string=''build(){Column({space:12}){TextInput({placeholder:'账号'}).onChange(v=>this.account=v)TextInput({placeholder:'密码',type:InputType.Password}).onChange(v=>this.password=v)Button("登录").onClick(async()=>{awaitthis.appStore.login(this.account,this.password)})}.padding(16)}}

八、退出登录怎么做?

在任意页面:

@Consume appStore:AppStoreButton("退出登录").onClick(()=>this.appStore.logout())

UI 会自动切回 Login 页面。


九、Token 如何自动带到请求中?

👉统一在 Service 层处理

headers:{Authorization:`Bearer${appStore.auth.token}`}

📌 不要在 UI 拼 Token
📌 网络层统一处理


十、这一篇你真正学会了什么?

你已经掌握:

✔ 登录系统的完整设计
✔ Token 管理
✔ 自动登录
✔ 全局状态共享
✔ Provider / Consume 用法
✔ 多页面登录态切换

这已经是商业 App 的标准做法


结语

登录系统不是一个页面,而是一整套状态管理体系。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 14:08:39

Kotaemon支持灰度发布新版本问答逻辑吗?

Kotaemon 支持灰度发布新版本问答逻辑吗? 在企业级 AI 系统的落地过程中,一个常见的挑战是:如何在不中断服务的前提下,安全地验证和上线新的问答逻辑?尤其是在金融、医疗或客服这类高敏感场景中,一次错误的…

作者头像 李华
网站建设 2026/6/9 17:42:56

20、Linux系统更新与安全保障全解析

Linux系统更新与安全保障全解析 1. 滚动发布与标准发布的对比 在Linux世界中,存在两种不同的发布模式:滚动发布和标准发布。这两种模式各有特点,对用户的系统管理方式和体验有着显著影响。 标准Linux发行版在固定的时间内得到支持,在此期间会不断获得更新。一旦支持期限…

作者头像 李华
网站建设 2026/6/9 20:28:27

165页满分PPT | 某商贸企业数字化蓝图整体规划方案

商贸企业在日常运营中,普遍面临着数据孤岛的严峻挑战。具体表现为库存信息、价格体系、会员数据、供应商资料等各自独立管理,缺乏有效整合与协同。这种状况直接导致了一系列经营困境:门店层面缺货与积压现象并存,促销活动与返利计…

作者头像 李华
网站建设 2026/6/10 0:32:01

高质量AI底座助推产业数智化,北电数智星火・大平台落地全国

日前,中国人民大学校友企业家联谊会代表团在会长张建明书记带队下到访北电数智。双方围绕数字经济与人工智能赋能产学研一体化展开深入交流,实地参观首个“星火大平台”标杆项目——星火761北京数字经济算力中心,充分了解了其设计理念、核心能…

作者头像 李华
网站建设 2026/6/10 12:39:50

Kotaemon能否实现自动摘要与关键信息提取?

Kotaemon能否实现自动摘要与关键信息提取? 在企业知识管理日益复杂的今天,一个典型场景是:法务人员需要在30分钟内审完一份80页的并购合同,找出所有关键责任条款;客服主管希望从上千条客户反馈中快速提炼出共性问题。…

作者头像 李华
网站建设 2026/6/10 15:02:35

25、深入探索:SharePoint与Microsoft Office的集成之道

深入探索:SharePoint与Microsoft Office的集成之道 内容类型作为文档模板 内容类型是SharePoint中非常有趣且实用的元素。它们是可重复使用的对象、设置和元数据,可应用于SharePoint中的特定类型内容。通过内容类型,你能够为SharePoint内的文档或项目创建可预测且易于管理的…

作者头像 李华