大家好,我是 jonssonyan
最近把以前做的权限管理系统重新整理了一下(将一些不规范的地方规范了一下,并且在关键地方写了注释),代码全部开源,这个项目是以现在主流的前后端分离模式开发的,包含前端(authority-ui)和后端(authority)两个工程,项目的开源地址在文章的最后
。
适宜人群
你可以借助本项目,学习 Java、SpringBoot、MybatisPlus、Shiro、JWT …
一个系统中权限管理是最基础的功能,你可以将本项目作为脚手架,在它的基础上进行二次开发,可以提高你开发软件的速度。
技术栈
后端:
- JDK 1.8
- MySQL 5.2.29
- SpringBoot
- MybatisPlus ORM 框架
- Shiro 权限控制
- JWT 单点登录
- Hibernate Validator 参数校验
- Swagger2 API 文档工具
前端:
- JavaScript
- Vue.js
- Element
- Axios
- Node v14.17.0
- yarn 1.22.21
项目简介
基于 SpringBoot 和 Vue.js 的权限管理系统,项目中没有涉及到过多的业务,主要是权限系统的设计与实现,基于 RBAC 权限模型,实现用户->角色->权限之间的关系,一个用户拥有一个或者多个角色,角色拥有多个权限,并且系统还实现了角色和菜单的动态关联。
以下是数据库模型的关系图:
项目的 SQL 文件在https://github.com/jonssonyan/authority/blob/master/docs/sql/
,在运行项目之前需要先将数据库:authority 建好,数据库中一共有 9 张表,user 表中默认有两个账户,分别是管理员账户和普通用户账户,当你启动好项目之后可以直接使用默认的账户进行登录,当然你也可以注册一个账户,新账户默认的角色是 user,也就是普通用户。
- 用户名: admin 密码: 123456 (管理员角色)
- 用户名: user1 密码: 123456 (普通用户角色)
登录管理员账户之后,自然看到的菜单更多,权限最全。管理员账户可以为每个账户分配角色,并且可以为角色授权,如果管理员将角色为 user 的查询分类的权限收回,那么普通用户账户查询分类的时候就会提示“没有权限”。
此时登录普通用户角色的账户,将不会有查询分类的权限。
项目的主要菜单是用户管理,角色管理,权限管理,实现了用户,角色,权限的动态控制,分类管理,商品管理,订单管理只是为了展示权限控制的效果,并没有实际的作用。另外角色和菜单也是动态关联的,角色表 role
和菜单表 menu_list
,通过第三张表role_menu_list
进行多对多关联。
视频教程
如果你看文字版教程看不懂,可以看我录制的视频教程。
项目介绍:https://www.bilibili.com/video/BV19U421d7CM/
项目部署:https://www.bilibili.com/video/BV1Fy421h7me/
项目开源地址
Spring Boot+Vue.js 权限管理系统前端: https://github.com/jonssonyan/authority-ui
Spring Boot+Vue.js 权限管理系统后端: https://github.com/jonssonyan/authority
欢迎 PR,感谢 Star