当前位置: 首页 > news >正文

鸿蒙开发基础-Web组件之cookie操作

使用ArkTS语言实现一个简单的免登录过程,向大家介绍基本的cookie管理操作。主要包含以下功能:

  1. 获取指定url对应的cookie的值。
  2. 设置cookie。
  3. 清除所有cookie。
  4. 免登录访问账户中心。

cookie读写操作

首次打开应用时,应用首页的Web组件内呈现的是登录界面。用户完成登录操作后,会跳转至账号中心界面。首页包含“读取cookie”、“设置cookie”和“删除cookie”等多个按钮,可对cookie进行读取、设置和删除等操作。

v2-5cf6b842b852d908517a4cbe32e56100_720w.gif

// WebIndex.ets
Column() {Text($r('app.string.navigator_name'))...Text($r('app.string.title_name'))...Web({src: CommonConstants.USER_CENTER_URL,controller: this.controller})...Row() {LinkButton({ buttonType: CookieOperation.GET_COOKIE, isNeedDivider: true })LinkButton({ buttonType: CookieOperation.SET_COOKIE, isNeedDivider: true })LinkButton({ buttonType: CookieOperation.DELETE_COOKIE, isNeedDivider: true })LinkButton({ buttonType: CookieOperation.VERIFY_COOKIE, isNeedDivider: false })}...
}
...

自定义组件LinkButton由Text组件和Divider分隔器组件组成。最后一个按钮没有分隔器,通过isNeedDivider标识符判断是否需要添加Divider分隔器组件。

// LinkButton.ets
@Component
export struct LinkButton {buttonType?: string;isNeedDivider?: boolean;build() {Row() {Text(this.buttonType).fontColor($r('app.color.link_blue')).fontSize(CommonConstants.BUTTON_SIZE).textAlign(TextAlign.Center).fontWeight(FontWeight.Normal).onClick(() => {this.operationMethod();})if (this.isNeedDivider) {Divider().vertical(true).margin(CommonConstants.DIVIDER_MARGIN).height(CommonConstants.DIVIDER_HEIGHT)}}}
}

每个按钮被点击时,都是调用operationMethod函数。函数根据不同操作,执行不同的代码内容。包括cookie的读、写和删除操作,以及页面跳转操作。

// LinkButton.ets
operationMethod(): void {try {if (this.buttonType === CookieOperation.GET_COOKIE) {let originCookie = web_webview.WebCookieManager.getCookie(CommonConstants.USER_CENTER_URL);showDialog(originCookie);} else if (this.buttonType === CookieOperation.SET_COOKIE) {web_webview.WebCookieManager.setCookie(CommonConstants.USER_ABOUT_URL, 'info=测试cookie写入');showDialog($r('app.string.write_success'));} else if (this.buttonType === CookieOperation.DELETE_COOKIE) {web_webview.WebCookieManager.deleteEntireCookie();let deleteMessage = $r('app.string.delete_success');showDialog(deleteMessage);} else {router.pushUrl({url: CommonConstants.PAGE_VERIFY})}} catch (error) {showDialog('Operation failed.'+JSON.stringify(error));}
}

cookie存储验证

一个应用中的所有Web组件共享一个WebCookie,因此一个应用中Web组件存储的cookie信息,也是可以共享的。当用户在应用内完成登录操作时,Web组件会自动存储登录的会话cookie。应用内其他页面可共享当前会话cookie信息,免去多余的登录操作。

v2-0055fbe9e3a2559d5db9e1475fba3093_720w.gif

该页面布局同样简单,由应用导航标题“Web组件”、内部标题“Web组件内”、加载的网页组成。分别对应一个Navigator导航组件、一个Text组件和一个Web组件。Navigator导航组件类型设置为返回(NavigationType.Back),内容由返回图标和应用标题组成,呈水平排列展示

// Verify.ets
Column() {Navigator({ target: CommonConstants.PAGE_INDEX, type: NavigationType.Back }) {Row() {Image($r('app.media.ic_back'))...Text($r('app.string.navigator_name'))...}...}...Text($r('app.string.title_name'))...Web({src: CommonConstants.USER_ABOUT_URL,controller: this.controller})...
}
...

本文章主要是对鸿蒙开发当中ArkTS语言的基础应用实战,Web组件里的cookie操作。更多的鸿蒙应用开发技术,可以前往我的主页学习更多,下面是一张鸿蒙的学习路线如图(略缩版):

高清完整版,保存在主页(附鸿蒙4.0笔记)

最终效果图如下:

http://www.lryc.cn/news/280645.html

相关文章:

  • 什么是k8s和声明式编程?
  • Fluids —— MicroSolvers DOP
  • 工业智能网关:HiWoo Box远程采集设备数据
  • Apollo之原理和使用讲解
  • 魅族MX4pro系统升级、降级
  • 【Docker】快速入门之Docker的安装及使用
  • 记录汇川:H5U于Factory IO测试13
  • PYTHON通过跳板机巡检CENTOS的简单实现
  • 网络配置以及命令详解
  • 商务外语MR混合现实仿真情景实训教学
  • 牛客周赛 Round 28 解题报告 | 珂学家 | 组合数学 + 离散化树状数组
  • Python系列(3)—— 变量
  • Java 并发性和多线程2
  • 最新消息:OpenAI GPT Store 正式上线,GPTs 应用商店来了!
  • memory泄露分析方法(java篇)
  • kubectlkubeletrancherhelmkubeadm这几个命令行工具是什么关系?
  • Day26 669修剪二叉搜索树 108有序数组转为二叉搜索树 538二叉搜索树转换为累加树
  • 优化CentOS 7.6的HTTP隧道代理网络性能
  • 第二篇ts,es6箭头函数结合typescript,和for...of
  • 异构多品牌高清视频监控接入-技术方案
  • 编程探秘:Python深渊之旅-----机器学习入门(七)
  • SpringMVC 学习博客记录
  • 重磅!OpenAI正式发布,自定义ChatGPT商店!
  • LeetCode讲解篇之47. 全排列 II
  • 机器学习~从入门到精通(二)线性回归算法和多元线性回归
  • IPv6组播--PIM
  • 如何在Spring Boot中使用EhCache缓存
  • PDF 文档解除密码
  • React16源码: React中的expirationTime过期时间的计算源码实现
  • 程序设计语言的分类