## 一、项目简介
JeePlatform项目是一款以SpringBoot为核心框架,集ORM框架Mybatis,Web层框架SpringMVC和多种开源组件框架而成的一款通用基础平台
代码结构图:
```
├─jeeplatform----------------------------父项目,公共依赖
│ │
│ ├─jeeplatform-admin--------------------------基础管理系统
│ │
│ ├─jeeplatform-cms-----------------------内容管理系统
│ │
│ ├─jeeplatform-common--------------------------通用工程
│ │
│ ├─jeeplatform-oa--------------------------协调办公系统
| |
| |─jeeplatform-provider-----------------------平台服务中心
│ │
│ ├─jeeplatform-provider-api-----------------------平台服务API
| |
│ ├─jeeplatform-sso-cas-----------------------CAS单点登录服务端
│ │
│ ├─jeeplatform--sso-oauth2---------------OAuth2.0单点登录服务端
│ │
```
## 二、系统设计
### 系统管理(模块名称jeeplatform-admin)
管理系统登录页面
ps:登录链接一般为:http://127.0.0.1:8080/jeeplatform/login
![Image text](https://gitee.com/362330721/jeeplatform/raw/master/screenshot/管理系统登录页面.png)
管理系统主页前端,可以适配移动端页面
![Image text](https://gitee.com/362330721/jeeplatform/raw/master/screenshot/适配移动端.png)
管理系统主页采用开源前端模板,具有换肤功能
![Image text](https://gitee.com/362330721/jeeplatform/raw/master/screenshot/系统主页墨绿主题.png)
![Image text](https://gitee.com/362330721/jeeplatform/raw/master/screenshot/系统主页清新主题.png)
管理系统主页,获取用户具有的权限,显示菜单
![Image text](https://gitee.com/362330721/jeeplatform/raw/master/screenshot/管理系统主页.png)
角色进行授权,只有超级管理员才具有权限
![Image text](https://gitee.com/362330721/jeeplatform/raw/master/screenshot/角色授权.png)
角色进行配置,可以学习一下RBAC(基于角色的权限控制)
![Image text](https://gitee.com/362330721/jeeplatform/raw/master/screenshot/角色配置.png)
使用JavaEmail插件实现邮件发送,记得需要开启SSl验证
![Image text](https://gitee.com/362330721/jeeplatform/raw/master/screenshot/发送邮件.png)
### OA管理系统(待开发)
接入CAS Server实现单点登录
### CMS管理系统(待开发)
暂时接入Oauth2.0实现的单点登录系统
## 四、业务方案
### 系统管理通用功能
- [ ] 单点登录: OAuth2.0+JWT单点登录/CAS单点登录
- [x] 用户管理: 系统用户
- [x] 角色管理: 按照企业系统职能进行角色分配,每个角色具有不同的系统操作权限
- [x] 权限管理: 权限管理细分到系统菜单权限
- [ ] 在线管理:管理在线用户,可以强制下线
- [x] 菜单管理:系统可以配置系统菜单,并分配不同的权限
- [ ] 报表统计:数据报表、用户分析
- [x] 系统监控:数据库等方面监控(采用Druid提供的)
- [x] 在线文档:SwaggerUI API在线文档管理
- [x] 通用接口:系统邮件发送功能、Excel报表功能
### OA系统通用功能(待开发)
- [x] 单点登录: CAS单点登录
- [ ] 考勤管理:请假流程
- [ ] 人事管理:机构管理、部门管理、员工管理
### CMS系统通用功能(待开发)
- [x] 单点登录: OAuth2.0+JWT单点登录
- [ ] 信息管理:文章管理、文章审核
...
## 五、技术方案
### 后台技术
* 工作流引擎:Activiti5(待定)
* ORM框架:Mybatis
* Web框架:SpringMVC
* 核心框架:SpringBoot
* 任务调度:Spring Task(待定)
* 权限安全:Apache Shiro、Spring Security
* 全文搜索引擎:Lucene(待定)
* 模板引擎:JSP(还没使用Thymeleaf,前端需要重构)
* 服务器页面包含技术:SSI(待定)
* 网页即时通讯:websocket
* 连接池:Druid(阿里开源)
* 日志处理:SLF4J(日志门面框架)、logback
* 缓存处理:Redis
* Excel表处理:POI
### 前端技术
* 文件上传:JQuery uploadify
* 树形结构:EasyUI Tree
* 日期插件:JQuery Date
* 弹窗框架:zDialog
* Cookie保存:JQuery Cookie
* 富文本编辑器:Baidu UEDitor
* 前端框架:Twitter Bootstrap
## 六、常见问题
运行jeeplatform打开页面404,如果是用idea的,就可以edit configurations->configuration->edit working directory设置为:$MODULE_DIR$
## 七、版本说明
* master版本
主干版本,实现简单的权限管理,单点登录方案有CAS和OAuth2.0+JWT两种方案,admin暂时没接单点,oa工程对接cas,cms对接OAuth2.0实现单点登录,微服务只是做了个demo,还没进行项目服务处理,所以并没有merge代码
* dev版本
dev版本代码和master分支基本一致
* 1.0.0版本
基础版,基本实现简单的权限管理,功能还需改善,权限控制还需要进行细粒度控制
* 1.1.0版本
进行单点登录对接实验的版本,拟采用两种方案,CAS实现的单点登录和OAuth2.0+JWT单点登录,admin工程暂时还没对接,oa工程对接CAS,cms工程对接OAuth2.0