【产品应用】AWTK开源串口屏开发(9)-用户和权限管理

原创 ZLG致远电子 2024-02-02 11:40
在AWTK串口屏中,内置用户管理和权限控制的模型,无需编码即可实现登录、登出、修改密码、权限控制、创建用户、删除用户等功能,本文介绍一下用户管理和权限控制的基本用法。


用户管理和权限控制是一个常用的功能。在工业软件中,通常将用户分为几种不同的角色,每种角色有不同的权限,比如管理员、操作员和维护员等等。在 AWTK 串口屏中,内置基本的用户管理和权限控制功能,可以满足常见的需求。开发者不需要编写代码,设计好用户界面,通过数据和命令绑定规则,即可实现用户和权限管理功能,比如登录、登出、修改密码、权限控制、创建用户、删除用户等功能。
本文介绍一下 AWTK 串口屏中的用户管理和权限控制功能。


1. 出厂默认用户

在下面的数据文件中,可以修改出厂默认的用户和密码。密码使用 sha256 加密,可以使用在线工具生成。
https://emn178.github.io/online-tools/sha256.html
design/default/data/user_manager.csv

比如 demo 中的默认用户是:

admin|0|8c6976e5b5410415bde908bd4dee15dfb167a9c873fc4bb8a81f6f2ab448a918|管理员(默认密码:admin)

2. 数据文件格式

用 CSV 格式的文件存储用户名和密码,每行一个用户,每行的格式如下:
  • 用户名。可以使用中文。
  • 角色。用来做实际的权限控制,怎么定义就怎么用。比如:0 表示管理员,1 表操作员,2 表示维护员。
  • 密码。使用 sha256 加密。
  • 备注。可以使用中文。

在后面的数据绑定中,name 表示用户名,role 表示角色,password 表示密码,memo 表示备注。


3. 用户登录

3.1 用户登录命令

当启用用户管理时,默认模型 (default) 会提供一个 login 的命令。

login 命令依赖两个属性:

  • login_username 登录的用户名。

  • login_password 登录的密码。

login 命令需要一个参数,用来指定登录成功后跳转的目标页面。

3.2 数据绑定

绑定属性

绑定规则

说明

v-data:value

{login_username}

用户名编辑器

v-data:value

{login_password, Mode=OneWayToModel, ToModel=sha256(value)}

密码编辑器

  • Mode=OneWayToModel 表示单向绑定,只能从控件到模型,主要是因为模型里的密码是加密后的哈希值,不能反向绑定到控件。

  • 表示将控件输入的数据使用 sha256 加密后,再赋值给模型。

3.3 命令绑定

绑定属性

绑定规则

说明

v-on:click

{login, Args=home_page}

登录按钮的点击事件。home_page 是登录成功后跳转的页面

3.4 demo 参考界面


4. 用户登录状态

4.1 用户登录状态

用户登录成功后,会在默认模型 (default) 中提供两个变量:

  • username 登录的用户名。

  • userrole 登录的用户角色。

userrole 是一个整数,可以通过 userrole 来控制权限。

4.2 数据绑定

绑定属性

绑定规则

说明

v-data:value

{username}

显示当前用名

v-data:value

{one_of(‘管理员;工程师;操作员’, userrole)}

显示当前的角色名

4.3 命令绑定

比如,只用管理员才能访问的页面,可以通过下面的命令绑定来实现:

绑定属性

绑定规则

说明

v-on:click

{navigate, Args=user_manager, AutoDisable=false}

AutoDisable 一定要设置为 false,否则不能绑定 enable 属性

v-data:enable

data:enable    {userrole==0}    

当前角色为管理员时,才启用本按钮

比如,只用管理员执行某些命令,可以通过下面的命令绑定来实现:

绑定属性

绑定规则

说明

v-on:click

{do_something, Args=xxx, AutoDisable=false}

AutoDisable 一定要设置为 false,否则不能绑定 enable 属性

v-data:enable

data:enable    {userrole==0}    

当前角色为管理员时,才启用本按钮

4.4 demo 参考界面
  • 管理员界面,全部功能可用。

  • 工程师界面,部分功能可用。


5. 修改密码

5.1 修改密码命令

当启用用户管理时,默认模型 (default) 会提供一个 change_password 的命令。
change_password 命令依赖两个属性:
  • change_password 修改的密码。
  • change_confirm_password 确认修改的密码。
change_password 命令不需要参数。

5.2 数据绑定

绑定属性

绑定规则

说明

v-data:value

{change_password, Mode=OneWayToModel, ToModel=sha256(value)}

密码编辑器

v-data:value

{change_confirm_password, Mode=OneWayToModel, ToModel=sha256(value)}

确认密码编辑器

5.3 命令绑定

绑定属性

绑定规则

说明

v-on:click

{change_password, CloseWindow=true}

确认按钮的点击事件。

5.4 demo 参考界面


6. 用户管理

前面的模型都是默认模型 (default),用户管理模型是 user_manager。

6.1 用户管理命令

当启用用户管理时,用户管理模型 (user_manager) 会提供一些命令。

  • add 添加用户。

  • remove 删除用户。

  • edit 编辑用户。

  • save 保存用户。

  • reload 重新加载用户。

  • set_selected 设置选中的用户。

6.2 数据绑定

绑定属性

绑定规则

说明

v-data:value

{selected_index}

选中的用户索引,在列表项目外使用。

v-data:value

{index}

序数,在列表项内使用。

v-data:value

{item.name}

用户名,在列表项内使用。

v-data:value

{one_of(‘管理员;工程师;操作员’, item.role)}

角色,在列表项内使用。

v-data:value

{item.memo}

备注,在列表项内使用。

6.3 命令绑定

绑定属性

绑定规则

说明

v-on:click

{add}

添加 按钮的点击事件。

v-on:click

{edit}

编辑 按钮的点击事件。

v-on:click

{save}

保存 按钮的点击事件。

v-on:click

{reload}

重新加载 按钮的点击事件。

v-on:click

{set_selected}

列表项的点击事件。

v-on:click

{remove, Args=selected_index, AutoDisable=false}

删除按钮的点击事件。AutoDisable 一定要设置为 false,否则不能绑定 enable 属性

为了不让用户删除管理员用户,可以设置删除按钮的 enable 属性。绑定规则如下:

绑定属性

绑定规则

说明

v-data:enable

{selected_index!=0}

当前选中的用户不是管理员时,启用本按钮。

6.4 demo 参考界面


7. 创建用户

user_manager 模型提供了一个 add 命令,用来创建用户。如果支持创建用户,需要提供一个创建用户的界面,窗口的名字必须是 user_manager_add。

通过 new 参数可以设置默认数据。比如:
user_manager(new=' |1| | |');

7.1 模型

创建用户的界面有自己的模型,代表当前创建的用户。

它具有下面的属性:

  • name 表示 username 用户名。

  • role 表示 role 角色。

  • password 表示 password 密码。

  • memo 表示 memo 备注。

它还提供了一个确认增加的命令。

  • add 命令。

7.2 数据绑定

绑定属性

绑定规则

说明

v-data:value

{name, validator=username}

用户名编辑器,内置数据校验器 username,用于检查用户名的有效性(如是否重名)

v-data:value

{role}

角色编辑器

v-data:value

{password, Mode=OneWayToModel, ToModel=sha256(value)}

密码编辑器

v-data:value

{memo}

备注编辑器

7.3 命令绑定

绑定属性

绑定规则

说明

v-on:click

{add, CloseWindow=true}

确认按钮的点击事件。

7.4 demo 参考界面


8. 编辑用户

user_manager 模型提供了一个 edit 命令,用来编辑用户。如果支持编辑用户,需要提供一个编辑用户的界面,窗口的名字必须是 user_manager_edit。

8.1 模型

编辑用户的界面有自己的模型,代表当前编辑的用户。
它具有下面的属性:
  • name 表示 username 用户名。
  • role 表示 role 角色。
  • memo 表示 memo 备注。
不需要额外的命令。

8.2 数据绑定

绑定属性

绑定规则

说明

v-data:value

{name}

用户名编辑器

v-data:value

{role, Trigger=Explicit}

角色编辑器,为了方便取消,采用显式更新

v-data:value

{memo, Trigger=Explicit}

备注编辑器,为了方便取消,采用显式更新

8.3 命令绑定

绑定属性

绑定规则

说明

v-on:click

{nothing, UpdateModel=true, CloseWindow=true}

确认按钮的点击事件。

v-on:click

{nothing, CloseWindow=true}

取消按钮的点击事件。

UpdateModel=true 表示更新模型,CloseWindow=true 表示关闭窗口。

8.4 demo 参考界面


9. 注意

  • 本项目并没有编写界面相关的代码,AWStudio 在 src/pages 目录下生成了一些代码框架,这些代码并没有用到,可以删除也可以不用管它,但是不能加入编译。

  • 实际开发时,可以参考 demo_user_manager 演示项目,在的它 UI 文件上修改。


  产品推荐

  技术交流群
长按识别如下二维码可加入“EsDA嵌入式系统设计自动化交流群”,与志同道合的朋友交流,并有专业技术人员为您答疑解惑,如有问题可以咨询小致微信zlgmcu-888。

更多往期文章,请点击“ 阅读原文 ”。

评论
  •     IPC-2581是基于ODB++标准、结合PCB行业特点而指定的PCB加工文件规范。    IPC-2581旨在替代CAM350格式,成为PCB加工行业的新的工业规范。    有一些免费软件,可以查看(不可修改)IPC-2581数据文件。这些软件典型用途是工艺校核。    1. Vu2581        出品:Downstream     
    电子知识打边炉 2025-01-22 11:12 49浏览
  •  光伏及击穿,都可视之为 复合的逆过程,但是,复合、光伏与击穿,不单是进程的方向相反,偏置状态也不一样,复合的工况,是正偏,光伏是零偏,击穿与漂移则是反偏,光伏的能源是外来的,而击穿消耗的是结区自身和电源的能量,漂移的载流子是 客席载流子,须借外延层才能引入,客席载流子 不受反偏PN结的空乏区阻碍,能漂不能漂,只取决于反偏PN结是否处于外延层的「射程」范围,而穿通的成因,则是因耗尽层的过度扩张,致使跟 端子、外延层或其他空乏区 碰触,当耗尽层融通,耐压 (反向阻断能力) 即告彻底丧失,
    MrCU204 2025-01-17 11:30 182浏览
  • 高速先生成员--黄刚这不马上就要过年了嘛,高速先生就不打算给大家上难度了,整一篇简单但很实用的文章给大伙瞧瞧好了。相信这个标题一出来,尤其对于PCB设计工程师来说,心就立马凉了半截。他们辛辛苦苦进行PCB的过孔设计,高速先生居然说设计多大的过孔他们不关心!另外估计这时候就跳出很多“挑刺”的粉丝了哈,因为翻看很多以往的文章,高速先生都表达了过孔孔径对高速性能的影响是很大的哦!咋滴,今天居然说孔径不关心了?别,别急哈,听高速先生在这篇文章中娓娓道来。首先还是要对各位设计工程师的设计表示肯定,毕竟像我
    一博科技 2025-01-21 16:17 100浏览
  •  万万没想到!科幻电影中的人形机器人,正在一步步走进我们人类的日常生活中来了。1月17日,乐聚将第100台全尺寸人形机器人交付北汽越野车,再次吹响了人形机器人疯狂进厂打工的号角。无独有尔,银河通用机器人作为一家成立不到两年时间的创业公司,在短短一年多时间内推出革命性的第一代产品Galbot G1,这是一款轮式、双臂、身体可折叠的人形机器人,得到了美团战投、经纬创投、IDG资本等众多投资方的认可。作为一家成立仅仅只有两年多时间的企业,智元机器人也把机器人从梦想带进了现实。2024年8月1
    刘旷 2025-01-21 11:15 390浏览
  • 现在为止,我们已经完成了Purple Pi OH主板的串口调试和部分配件的连接,接下来,让我们趁热打铁,完成剩余配件的连接!注:配件连接前请断开主板所有供电,避免敏感电路损坏!1.1 耳机接口主板有一路OTMP 标准四节耳机座J6,具备进行音频输出及录音功能,接入耳机后声音将优先从耳机输出,如下图所示:1.21.2 相机接口MIPI CSI 接口如上图所示,支持OV5648 和OV8858 摄像头模组。接入摄像头模组后,使用系统相机软件打开相机拍照和录像,如下图所示:1.3 以太网接口主板有一路
    Industio_触觉智能 2025-01-20 11:04 150浏览
  • 2024年是很平淡的一年,能保住饭碗就是万幸了,公司业绩不好,跳槽又不敢跳,还有一个原因就是老板对我们这些员工还是很好的,碍于人情也不能在公司困难时去雪上加霜。在工作其间遇到的大问题没有,小问题还是有不少,这里就举一两个来说一下。第一个就是,先看下下面的这个封装,你能猜出它的引脚间距是多少吗?这种排线座比较常规的是0.6mm间距(即排线是0.3mm间距)的,而这个规格也是我们用得最多的,所以我们按惯性思维来看的话,就会认为这个座子就是0.6mm间距的,这样往往就不会去细看规格书了,所以这次的运气
    wuliangu 2025-01-21 00:15 183浏览
  • 嘿,咱来聊聊RISC-V MCU技术哈。 这RISC-V MCU技术呢,简单来说就是基于一个叫RISC-V的指令集架构做出的微控制器技术。RISC-V这个啊,2010年的时候,是加州大学伯克利分校的研究团队弄出来的,目的就是想搞个新的、开放的指令集架构,能跟上现代计算的需要。到了2015年,专门成立了个RISC-V基金会,让这个架构更标准,也更好地推广开了。这几年啊,这个RISC-V的生态系统发展得可快了,好多公司和机构都加入了RISC-V International,还推出了不少RISC-V
    丙丁先生 2025-01-21 12:10 111浏览
  • 本文介绍瑞芯微开发板/主板Android配置APK默认开启性能模式方法,开启性能模式后,APK的CPU使用优先级会有所提高。触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。源码修改修改源码根目录下文件device/rockchip/rk3562/package_performance.xml并添加以下内容,注意"+"号为添加内容,"com.tencent.mm"为AP
    Industio_触觉智能 2025-01-17 14:09 164浏览
  • 数字隔离芯片是一种实现电气隔离功能的集成电路,在工业自动化、汽车电子、光伏储能与电力通信等领域的电气系统中发挥着至关重要的作用。其不仅可令高、低压系统之间相互独立,提高低压系统的抗干扰能力,同时还可确保高、低压系统之间的安全交互,使系统稳定工作,并避免操作者遭受来自高压系统的电击伤害。典型数字隔离芯片的简化原理图值得一提的是,数字隔离芯片历经多年发展,其应用范围已十分广泛,凡涉及到在高、低压系统之间进行信号传输的场景中基本都需要应用到此种芯片。那么,电气工程师在进行电路设计时到底该如何评估选择一
    华普微HOPERF 2025-01-20 16:50 73浏览
  • 临近春节,各方社交及应酬也变得多起来了,甚至一月份就排满了各式约见。有的是关系好的专业朋友的周末“恳谈会”,基本是关于2025年经济预判的话题,以及如何稳定工作等话题;但更多的预约是来自几个客户老板及副总裁们的见面,他们为今年的经济预判与企业发展焦虑而来。在聊天过程中,我发现今年的聊天有个很有意思的“点”,挺多人尤其关心我到底是怎么成长成现在的多领域风格的,还能掌握一些经济趋势的分析能力,到底学过哪些专业、在企业管过哪些具体事情?单单就这个一个月内,我就重复了数次“为什么”,再辅以我上次写的:《
    牛言喵语 2025-01-22 17:10 41浏览
  • Ubuntu20.04默认情况下为root账号自动登录,本文介绍如何取消root账号自动登录,改为通过输入账号密码登录,使用触觉智能EVB3568鸿蒙开发板演示,搭载瑞芯微RK3568,四核A55处理器,主频2.0Ghz,1T算力NPU;支持OpenHarmony5.0及Linux、Android等操作系统,接口丰富,开发评估快人一步!添加新账号1、使用adduser命令来添加新用户,用户名以industio为例,系统会提示设置密码以及其他信息,您可以根据需要填写或跳过,命令如下:root@id
    Industio_触觉智能 2025-01-17 14:14 121浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦