Qt编写物联网管理平台31-用户权限管理
一、前言
随着需求的不断变化,功能的增多,在用户信息这块,除了需要用户登录退出验证以外,还需要有个简单的用户权限逻辑处理,比如限定某些用户只有查看权限,没有删除记录、清空记录、系统设置的权限,与之相对应的就是用户信息表中,存储有该用户具备哪些权限,当该用户登录成功以后,对应的权限应用到各个界面逻辑中,一般都是在触发了对应的显示或者单击后处理,比如不具备删除记录权限,则在对应的删除记录代码中过滤处理,判断当前登录的用户是否具备该权限,不具备则弹出提示,不做处理。还有一个就是切换界面的时候,没有到该界面的权限弹出提示,并仍然停留在上一个界面。
在十几年的从业生涯中,最开始编程的时候,也做过简单的权限管理,思路极其简单那就是根据用户类型写死,比如某个用户是管理员类型,则具备所有权限,某个用户是操作员类型,则不能有删除记录、用户管理的权限。好处是容易理解,逻辑简单到爆,缺点是代码写死,不能动态控制某个拥有某个模块的权限。暂且将这种处理叫做v0.1版本。
为了能够更进一步的拓展功能,后面修改过用户权限管理,暂且称为v0.2版本。在用户信息表中增加了一个用户权限字段,字符串表示 1|0|1 之类的,按照顺序约定对应位是哪个模块,1表示有该模块的权限,0表示没有权限,相对于v0.1版本的时候,可以控制不同模块的权限,相对灵活一些,但是还是不够通用,对约定的要求极其严格。
于是来到了现在的v0.3版本,索性增加了7个用户权限字段,对应用户7种模块权限,至于该种权限是对应哪个模块,填入对应的字符串名称就行,这样可以做一个通用的权限校验功能,不用用户权限验证代码写的到处都是,用户拥有该名称的权限则通过,不具备则弹出提示,一般常规的权限就有系统设置、删除记录、用户管理。
二、功能特点
2.1 软件模块
2.2 基础功能
2.3 特色功能
三、体验地址
四、效果图
五、相关代码
#include "userhelper.h" #include "quihelper.h"QString UserHelper::CurrentUserName = "admin"; QString UserHelper::CurrentUserPwd = "admin"; QString UserHelper::CurrentUserType = QString::fromUtf8("管理员"); QList<bool> UserHelper::UserPermission = QList<bool>() << true << true << true << true << true << true << true; QStringList UserHelper::PermissionName = QStringList() << QString::fromUtf8("系统设置|删除记录|模块A|模块B|模块C|模块D|模块E").split("|");int UserHelper::UserInfo_Count = 0; QList<QString> UserHelper::UserInfo_UserName = QList<QString>(); QList<QString> UserHelper::UserInfo_UserPwd = QList<QString>(); QList<QString> UserHelper::UserInfo_UserType = QList<QString>(); QList<QString> UserHelper::UserInfo_Permission1 = QList<QString>(); QList<QString> UserHelper::UserInfo_Permission2 = QList<QString>(); QList<QString> UserHelper::UserInfo_Permission3 = QList<QString>(); QList<QString> UserHelper::UserInfo_Permission4 = QList<QString>(); QList<QString> UserHelper::UserInfo_Permission5 = QList<QString>(); QList<QString> UserHelper::UserInfo_Permission6 = QList<QString>(); QList<QString> UserHelper::UserInfo_Permission7 = QList<QString>();void UserHelper::loadUserInfo() {UserHelper::UserInfo_Count = 0;UserHelper::UserInfo_UserName.clear();UserHelper::UserInfo_UserPwd.clear();UserHelper::UserInfo_UserType.clear();UserHelper::UserInfo_Permission1.clear();UserHelper::UserInfo_Permission2.clear();UserHelper::UserInfo_Permission3.clear();UserHelper::UserInfo_Permission4.clear();UserHelper::UserInfo_Permission5.clear();UserHelper::UserInfo_Permission6.clear();UserHelper::UserInfo_Permission7.clear();QString column = "Permission1,Permission2,Permission3,Permission4,Permission5,Permission6,Permission7";QString sql = QString("select UserName,UserPwd,UserType,%1 from UserInfo").arg(column);QSqlQuery query;if (!query.exec(sql)) {qDebug() << TIMEMS << query.lastError().text() << sql;return;}while (query.next()) {QString userName = query.value(0).toString();QString userPwd = query.value(1).toString();QString userType = query.value(2).toString();QString permission1 = query.value(3).toString();QString permission2 = query.value(4).toString();QString permission3 = query.value(5).toString();QString permission4 = query.value(6).toString();QString permission5 = query.value(7).toString();QString permission6 = query.value(8).toString();QString permission7 = query.value(9).toString();UserHelper::UserInfo_Count++;UserHelper::UserInfo_UserName << userName;UserHelper::UserInfo_UserPwd << userPwd;UserHelper::UserInfo_UserType << userType;UserHelper::UserInfo_Permission1 << permission1;UserHelper::UserInfo_Permission2 << permission2;UserHelper::UserInfo_Permission3 << permission3;UserHelper::UserInfo_Permission4 << permission4;UserHelper::UserInfo_Permission5 << permission5;UserHelper::UserInfo_Permission6 << permission6;UserHelper::UserInfo_Permission7 << permission7;} }void UserHelper::clearUserInfo() {QString sql = "delete from UserInfo where UserName!='admin'";DbHelper::execSql(sql); }void UserHelper::updateUserInfo(const QString &userName, const QString &userPwd) {QString sql = QString("update UserInfo set UserPwd='%1' where UserName='%2'").arg(userPwd).arg(userName);DbHelper::execSql(sql); }void UserHelper::getUserInfo() {UserHelper::getUserInfo(UserHelper::CurrentUserName, UserHelper::CurrentUserPwd, UserHelper::CurrentUserType, UserHelper::UserPermission); }void UserHelper::getUserInfo(const QString &userName, QString &userPwd, QString &userType, QList<bool> &permission) {QString column = "Permission1,Permission2,Permission3,Permission4,Permission5,Permission6,Permission7";QString sql = QString("select UserPwd,UserType,%1 from UserInfo where UserName='%2'").arg(column).arg(userName);QSqlQuery query;if (!query.exec(sql)) {qDebug() << TIMEMS << query.lastError().text() << sql;return;}if (query.next()) {userPwd = query.value(0).toString();userType = query.value(1).toString();for (int i = 0; i < 7; ++i) {permission[i] = (query.value(i + 2).toString() == "启用");}}//qDebug() << TIMEMS << UserHelper::CurrentUserName << UserHelper::CurrentUserPwd << UserHelper::CurrentUserType << UserHelper::UserPermission; }bool UserHelper::checkPermission(const QString &text) {//从权限模块名称找到当前模块是否需要授权//可能对应按钮的文本有空格要去掉再比较 比如权限文本设定的是 用户管理 而实际按钮是 用 户 管 理QString flag = text; #if (QT_VERSION >= QT_VERSION_CHECK(6,0,0))flag.remove(QRegularExpression("\\s")); #elseflag.remove(QRegExp("\\s")); #endifint index = UserHelper::PermissionName.indexOf(flag);if (index >= 0) {if (!UserHelper::UserPermission.at(index)) {QUIHelper::showMessageBoxError(QString("当前用户没有 [%1] 权限!").arg(text), 3);return false;}}return true; }总结
以上是生活随笔为你收集整理的Qt编写物联网管理平台31-用户权限管理的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: 基于树莓派采集网关1
- 下一篇: 亲民地理-第44期-美国的车文化_我是亲