演示地址:[http://123.56.169.21/dongbb/](http://123.56.169.21/dongbb/)
演示环境用户密码:因为密码会不定期更换,所以请大家扫码关注公众号,回复:dongbb ,获取登陆密码
![](https://img.kancloud.cn/65/0f/650fc75e6f01d43ea03bb4c81f866cc6_252x249.png)
> 请大家爱惜演示环境,自己创建的数据自己删除、修改。不要去删除修改他人创建的数据。如果多次删改“权限数据”造成演示环境,无法使用的情况,我将采取禁用权限的手段,大家的可操作空间将会缩小。
源码地址:[https://gitee.com/hanxt/dongbb](https://gitee.com/hanxt/dongbb)
## 一、文档核心价值
将**VUE + SpringBoot2.0+JWT核心的前后端分离web**应用脚手架项目:dongbb,**完整设计及开发过程一步一步的记录下来,方便技术爱好者学习掌握。** 以期学习者自己能够完成优化、修改,适用于自己的项目。这个文档和项目我是一边开发一边写的,开发到哪写到哪!
所以:**此文档核心价值是教你如何开发一个权限管理平台**,不是我开发好一个平台教你如何使用,这种文档目前还是比较稀缺的资源!
> 本文档只记录DongBB第一阶段的开发过程及后续针对该阶段内容的优化更新,第一阶段指的是:前后端分离项目基础架构 + RBAC用户、角色、权限管理系统的基础内容(具体内容看文档目录)。后续可能基于此项目开发工作流、微服务等,但不在此文档的记录范围。
## 二、 事先说明
我觉得我的文档已经写得足够细致了,但仍然会有的朋友买了这文档之后,觉得我写的仍然不够细,或者没达到你的要求,毕竟每个人的基础知识储备和理解能力是不一样的。**我无法让每个人都满意,所以以下内容事先说明,介意的千万别买,不愿意因此多费口舌。**
* 不要误解“一步一步教你开发”的含义?我会一步一步记录开发的过程,但是不等于用到VUE我会去讲VUE基础语法、不等于遇到Spring Boot我会去讲web开发基础,也不会去讲CSS、HTML基础,更不会去讲javascript、ajax等等基础知识。这样的发散的知识文档,我做不到的。
* **所以这篇文档更注重“实战”,“实战”之前你得有一定的训练基础和理论知识。** 此文档更多的是面向有一定java Spring web开发和vue基础知识的,希望提升自己的中级以上的开发人员来学习。如果你的基础知识有问题,或者我讲的你无法理解看不明白,建议你先去学习这几篇文档。再来看本文档!
[《手摸手教你学Spring Boot2.0》](https://www.kancloud.cn/hanxt/springboot2/content)
[《vue深入浅出系列》](https://www.kancloud.cn/hanxt/vuejs2/content)
[《Spring Security-JWT-OAuth2一本通》](https://www.kancloud.cn/hanxt/springsecurity/content)
## 三、通过该文档你能得到什么
* 基于JWT的前后端分离应用,以SpringBoot和Vue为基础该如何开发
* 如何基于RBAC数据库权限模型实现基础权限管理系统
* 如何做菜单查看权限,和“数据库可配”的接口访问权限
* 以及基础的“用户管理”、“角色管理”、“菜单管理”、“接口管理”、“组织管理”等基础权限管理功能。
* 角色权限控制精确到:**可数据库配置的“数据接口访问权限”**,大部分的开源框架只精确到“菜单层面”。
* **标准的RBAC权限管理**,基于角色的权限管理。
* **只有JWT,没有Session**。只有最简JWT认证授权状态管理,**开发过程不使用任何session**、更没有redis集中session。面向那些希望节省服务端部署资源,并且希望灵活实现分布式扩展的应用场景。
* **只用element-ui**,不引入其他对element-ui二次封装的UI框架,保证灵活性,降低技术栈学习成本。跟随社区成长、兼容。
* 统一的接口数据结构、全局的异常处理
* 使用mybatis代码自动生成,针对单表的数据操作不写SQL
* ……等
> 后续我还会在此版本的基础上开发,DongBB-cloud(Spring Cloud版本)。面向的应用场景将会有所不同。(会另起文档,不是此文档的内容)
## 字母哥铁粉
字母哥铁粉请加这个群:[字母哥铁粉超级福利群](http://www.zimug.com/other/%e5%ad%97%e6%af%8d%e5%93%a5%e8%b6%85%e7%ba%a7vip%e7%a6%8f%e5%88%a9%e7%be%a4-%e5%8a%a0%e5%85%a5%e6%96%b9%e6%b3%95/.html)
## 技术交流
* 加QQ群:300139299。
* 我可能一天只看一次加“好友消息”,所以加群之后不要着急,加群的时候注明来源,否则不会通过!
- 开发过程文档内容介绍
- 作者的其他作品推荐
- vue深入浅出系列
- 手摸手教你学Spring Boot2.0
- Spring Security-JWT-OAuth2一本通
- 实战SpringCloud微服务从青铜到王者
- 项目文档
- DongBB项目介绍
- 子模块介绍
- 环境部署
- 阿里云CentOS7-搭建Mysql
- 阿里云CentOS7-JDK安装
- 阿里云CentOS7-安装nginx
- 部署SpringBoot后端应用
- 前端vue打包部署nginx
- 关于学员若干问题的解答
- 代码生成器(独立开源项目)
- 设计宗旨及思路
- 代码生成器的安装
- 代码生成器的使用方法
- 基础框架搭建
- 【前端】搭建vue前端框架
- 【前端】目录结构及配置调整
- 【前端】封装及使用axios
- 【后端】IDEA多模块springboot项目
- 【后端】统一接口响应的数据结构
- 实现JWT认证授权
- 【后端】数据库权限模型设计
- 【后端】jwt-spring-boot-starter说明
- 【后端】JWT认证及令牌刷新接口
- 【前端】开发用户密码登录页面
- 【前端】开发登录认证功能
- 【前端】JWT令牌的存储携带与刷新
- 【问题】跨域访问等问题的处理
- 系统布局菜单Tab前端实现
- 【前端】整体布局的实现
- 【前端】侧边栏多级菜单
- 【前端】菜单侧边栏收缩
- 【前端】JSON数据加载菜单
- 【前端】菜单项前端路由及组件
- 【前端】结合vuex实现导航tab
- 以用户信息为例讲接口鉴权设计
- 【前端】开发个人中心相关功能
- 【前端】导航Tab的功能优化
- 【后端】系统接口多层鉴权设计
- 【后端】持久层通用模块
- 【后端】以用户信息为例讲接口开发
- 【前端】用户信息接口与加载进度条
- 【综合】HTTP状态码与业务统一
- 组织管理功能-树形结构精讲
- 【前端】理解树形表格展示结构
- 【后端】Mysql树形结构数据封装
- 【功能】Table查询重置的实现
- 【前端】树形下拉单选组件封装
- 【后端】增删改服务及接口实现
- 【前端】增删改功能的前端实现
- 菜单管理与接口分类管理
- 菜单管理功能类比实现(树形)
- 接口分类管理类比实现(树形)
- 角色管理与权限分配
- 【后端】角色管理CURD及接口定义
- 【前端】角色管理CURD
- 【前端】树形多项勾选组件封装
- 【后端】权限初始化及持久化接口
- 【前端】实现角色权限的分配
- 用户管理功能实现
- 【后端】用户管理后端接口及服务
- 【前端】查询分页与日期组件
- 【前端】使用组织树查询用户
- 【前端】增删改Mixin代码复用
- 【功能】用户角色分配功能开发
- 【功能】密码重置功能开发
- 【功能】登录提示修改默认密码
- 再谈菜单查看及接口访问权限
- 【使用】配置菜单接口角色用户权限
- 【后端】按数据库权限查询菜单
- 【前端】菜单栏数据加载渲染
- 全局配置参数功能设计与使用
- 【后端】数据库全局参数配置接口
- 【前端】加载及使用全局配置参数
- 【功能】参数配置管理功能开发
- 数据字典设计及使用
- 【后端】数据库数据字典接口
- 【前端】数据字典数据的加载
- 【前端】DictSelect组件封装与使用
- 【功能】数据字典管理功能的开发
- 1.0里程碑(优化补充调整)
- Header左侧样式优化
- Header右侧样式优化
- 为二级菜单增加图标
- 【bug修正】导航路由逻辑判断
- 引入MybatisPlus
- api函数定义模块拆分
- 通用字段自动填充
- 去掉无意义root节点展示
- 禁用状态设置
- 用户禁用状态
- 角色组织菜单接口状态
- 各种禁用状态背后的规则
- 应用缓存设计与实现
- 应用缓存设计定义
- EhCache缓存集成
- 如何保证缓存一致性(一)
- 如何保证缓存一致性(二)
- 如何保证缓存一致性(三)
- 换成分布式redis缓存
- 整合动态菜单与动态路由
- 需求说明
- 实现隐藏菜单功能
- 按权限加载前端路由