Awesome Open Source
Awesome Open Source

Build Status Join the chat at https://gitter.im/jeeplatform/community

一、项目简介

JeePlatform项目是一款以SpringBoot为核心框架,集ORM框架Mybatis,Web层框架SpringMVC和多种开源组件框架而成的一款通用基础平台,代码已经捐赠给开源中国社区:https://www.oschina.net/p/jeeplatform

代码结构图:

├─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

管理系统主页前端,可以适配移动端页面 Image text

管理系统主页采用开源前端模板,具有换肤功能 Image text

Image text

管理系统主页,获取用户具有的权限,显示菜单 Image text

角色进行授权,只有超级管理员才具有权限 Image text

角色进行配置,可以学习一下RBAC(基于角色的权限控制) Image text

使用JavaEmail插件实现邮件发送,记得需要开启SSl验证 Image text

OA管理系统(待开发)

接入CAS Server实现单点登录

CMS管理系统(待开发)

暂时接入Oauth2.0实现的单点登录系统

三、关键技术

CAS单点登录基础(模块名称jeeplatform-sso-cas)(功能修整中)

项目采用CAS实现单点登录,单点登录集群搭建可以参考博客: http://blog.csdn.net/u014427391/article/details/78653482 项目单点登录:使用nginx作为负载均衡,使用redis存储tomcat session,来实现集群中tomcat session的共享,使用redis作为cas ticket的仓库,来实现集群中cas ticket的一致性。OA已经对接CAS,admin工程暂时不对接CAS

图来自官网,这里简单介绍一下,从图可以看出,CAS支持多种方式的认证,一种是LDAP的、比较常见的数据库Database的JDBC,还有Active Directory等等;支持的协议有Custom Protocol 、 CAS 、 OAuth 、 OpenID 、 RESTful API 、 SAML1.1 、 SAML2.0 等

这里写图片描述

这里写图片描述

单点登录集群方案如图 Image text

OAuth2.0单点登录基础(模块名称jeeplatform-sso-oauth2)(功能修整中)

在这里插入图片描述

SpringBoot集成Redis缓存处理(Spring AOP实现)

先从Redis里获取缓存,查询不到,就查询MySQL数据库,然后再保存到Redis缓存里,下次查询时直接调用Redis缓存,详情参考博客:链接

这里写图片描述

可以看到Redis里保存到了缓存

这里写图片描述

四、业务方案

系统管理通用功能

  • [ ] 单点登录: 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

八、项目技术博客介绍

为了帮助学习者更好地理解代码,下面给出自己写的一些博客链接

Java框架

SpringBoot

我的Springboot系列博客可以参考我的专栏:SpringBoot系列博客

RPC框架

单点登录

Docker笔记


Get A Weekly Email With Trending Projects For These Topics
No Spam. Unsubscribe easily at any time.
Javascript (1,551,389
Spring Boot (12,260
Jquery (7,865
Redis (6,735
Ajax (2,178
Spring Mvc (1,864
Mybatis (1,514
Restful (1,279
Freemarker (839
Zookeeper (750
Javaee (726
Thymeleaf (691
Dubbo (484
Solr (457
Shiro (414
Aop (387
Lucene (259
Druid (231
Poi (218
Related Projects