| ├── zheng-upms-rpc-service — rpc服务提供者

| └── zheng-upms-server — 用户权限系统及SSO服务端[端口:1111]

├── zheng-cms — 内容管理系统

| ├── zheng-cms-common — cms系统公共模块

| ├── zheng-cms-dao — 代码生成模块,无需开发

| ├── zheng-cms-rpc-api — rpc接口包

| ├── zheng-cms-rpc-service — rpc服务提供者

| ├── zheng-cms-search — 搜索服务[端口:2221]

| ├── zheng-cms-admin — 后台管理[端口:2222]

| ├── zheng-cms-job — 消息队列、任务调度等[端口:2223]

| └── zheng-cms-web — 网站前台[端口:2224]

├── zheng-pay — 支付系统

| ├── zheng-pay-common — pay系统公共模块

| ├── zheng-pay-dao — 代码生成模块,无需开发

| ├── zheng-pay-rpc-api — rpc接口包

| ├── zheng-pay-rpc-service — rpc服务提供者

| ├── zheng-pay-sdk — 开发工具包

| ├── zheng-pay-admin — 后台管理[端口:3331]

| └── zheng-pay-web — 演示示例[端口:3332]

├── zheng-ucenter — 用户系统(包括第三方登录)

| ├── zheng-ucenter-common — ucenter系统公共模块

| ├── zheng-ucenter-dao — 代码生成模块,无需开发

| ├── zheng-ucenter-rpc-api — rpc接口包

| ├── zheng-ucenter-rpc-service — rpc服务提供者

| └── zheng-ucenter-web — 网站前台[端口:4441]

├── zheng-wechat — 微信系统

| ├── zheng-wechat-mp — 微信公众号管理系统

| | ├── zheng-wechat-mp-dao — 代码生成模块,无需开发

| | ├── zheng-wechat-mp-service — 业务逻辑

| | └── zheng-wechat-mp-admin — 后台管理[端口:5551]

| └── zheng-ucenter-app — 微信小程序后台

├── zheng-api — API接口总线系统

| ├── zheng-api-common — api系统公共模块

| ├── zheng-api-rpc-api — rpc接口包

| ├── zheng-api-rpc-service — rpc服务提供者

| └── zheng-api-server — api系统服务端[端口:6666]

├── zheng-oss — 对象存储系统

| ├── zheng-oss-sdk — 开发工具包

| ├── zheng-oss-web — 前台接口[端口:7771]

| └── zheng-oss-admin — 后台管理[端口:7772]

├── zheng-message — 实时通知系统

| ├── zheng-message-sdk — 开发工具包

| ├── zheng-message-server — 服务端[端口:8881,SocketIO端口:8882]

| └── zheng-message-client — 客户端

├── zheng-shop — 电子商务系统

└── zheng-demo — 示例模块(包含一些示例代码等)

 ├── zheng-demo-rpc-api -- rpc接口包

 ├── zheng-demo-rpc-service -- rpc服务提供者

 └── zheng-demo-web -- 演示示例[端口:9999]


### 技术选型

| 技术 | 名称 | 官网 |

| --- | --- | --- |

| Spring Framework | 容器 | [http://projects.spring.io/spring-framework/](
) |

| SpringMVC | MVC框架 | [http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#mvc](
) |

| Apache Shiro | 安全框架 | [http://shiro.apache.org/](
) |

| Spring session | 分布式Session管理 | [http://projects.spring.io/spring-session/](
) |

| MyBatis | ORM框架 | [http://www.mybatis.org/mybatis-3/zh/index.html](
) |

| MyBatis Generator | 代码生成 | [http://www.mybatis.org/generator/index.html](
) |

| PageHelper | MyBatis物理分页插件 | [http://git.oschina.net/free/Mybatis/_PageHelper](
) |

| Druid | 数据库连接池 | [https://github.com/alibaba/druid](
) |

| FluentValidator | 校验框架 | [https://github.com/neoremind/fluent-validator](
) |

| Thymeleaf | 模板引擎 | [http://www.thymeleaf.org/](
) |

| Velocity | 模板引擎 | [http://velocity.apache.org/](
) |

| ZooKeeper | 分布式协调服务 | [http://zookeeper.apache.org/](
) |

| Dubbo | 分布式服务框架 | [http://dubbo.io/](
) |

| TBSchedule & elastic-job | 分布式调度框架 | [https://github.com/dangdangdotcom/elastic-job](
) |

| Redis | 分布式缓存数据库 | [https://redis.io/](
) |

| Solr & Elasticsearch | 分布式全文搜索引擎 | [http://lucene.apache.org/solr/](
)?[https://www.elastic.co/](
) |

| Quartz | 作业调度框架 | [http://www.quartz-scheduler.org/](
) |

| Ehcache | 进程内缓存框架 | [http://www.ehcache.org/](
) |

| ActiveMQ | 消息队列 | [http://activemq.apache.org/](
) |

| JStorm | 实时流式计算框架 | [http://jstorm.io/](
) |

| FastDFS | 分布式文件系统 | [https://github.com/happyfish100/fastdfs](
) |

| Log4J | 日志组件 | [http://logging.apache.org/log4j/1.2/](
) |

| Swagger2 | 接口测试框架 | [http://swagger.io/](
) |

| sequence | 分布式高效ID生产 | [http://git.oschina.net/yu120/sequence](
) |

| AliOSS & Qiniu & QcloudCOS | 云存储 | [https://www.aliyun.com/product/oss/](
)?[http://www.qiniu.com/](
)?[https://www.qcloud.com/product/cos](
) |

| Protobuf & json | 数据序列化 | [https://github.com/google/protobuf](
) |

| Jenkins | 持续集成工具 | [https://jenkins.io/index.html](
) |

| Maven | 项目构建管理 | [http://maven.apache.org/](
) |

| Netty-socketio | 实时推送 | [https://github.com/mrniko/netty-socketio](
) |

前端技术:

| 技术 | 名称 | 官网 |

| --- | --- | --- |

| jQuery | 函式库 | [http://jquery.com/](
) |

| Bootstrap | 前端框架 | [http://getbootstrap.com/](
) |

| Bootstrap-table | Bootstrap数据表格 | [http://bootstrap-table.wenzhixin.net.cn/](
) |

| Font-awesome | 字体图标 | [http://fontawesome.io/](
) |

| material-design-iconic-font | 字体图标 | [https://github.com/zavoloklom/material-design-iconic-font](
) |

| Waves | 点击效果插件 | [https://github.com/fians/Waves](
) |

| zTree | 树插件 | [http://www.treejs.cn/v3/](
) |

| Select2 | 选择框插件 | [https://github.com/select2/select2](
) |

| jquery-confirm | 弹出窗口插件 | [https://github.com/craftpip/jquery-confirm](
) |

| jQuery EasyUI | 基于jQuery的UI插件集合体 | [http://www.jeasyui.com](
) |

| React | 界面构建框架 | [https://github.com/facebook/react](
) |

| Editor.md | Markdown编辑器 | [https://github.com/pandao/editor.md](
) |

| zhengAdmin | 后台管理系统模板 | [https://github.com/shuzheng/zhengAdmin](
) |

| autoMail | 邮箱地址自动补全插件 | [https://github.com/shuzheng/autoMail](
) |

| zheng.jprogress.js | 加载进度条插件 | [https://github.com/shuzheng/zheng.jprogress.js](
) |

| zheng.jtotop.js | 返回顶部插件 | [https://github.com/shuzheng/zheng.jtotop.js](
) |

| socket.io.js | SocketIO插件 | [https://socket.io/](
) |

**架构图**

![](https://s2.51cto.com/images/20210829/1630167606491864.jpg)

**模块依赖**

![](https://s2.51cto.com/images/20210829/1630167607145338.jpg)

**模块介绍**

> zheng-common

Spring+SpringMVC+Mybatis框架集成公共模块,包括公共配置、MybatisGenerator扩展插件、通用BaseService、工具类等。

> zheng-admin

基于bootstrap实现的响应式Material Design风格的通用后台管理系统,`zheng`项目所有后台系统都是使用该模块界面作为前端展示。

> zheng-ui

各个子系统前台thymeleaf模板,前端资源模块,使用nginx代理,实现动静分离。

> zheng-upms

本系统是基于RBAC授权和基于用户授权的细粒度权限控制通用平台,并提供单点登录、会话管理和日志管理。接入的系统可自由定义组织、角色、权限、资源等。用户权限=所拥有角色权限合集+用户加权限-用户减权限,优先级:用户减权限>用户加权限>角色权限

> zheng-oss

文件存储系统,提供四种方案:

*   阿里云?OSS

*   腾讯云?COS

*   七牛云

*   本地分布式存储

![](https://s2.51cto.com/images/20210829/1630167607585838.jpg)

> zheng-api

服务网关,对外暴露统一规范的接口和包装响应结果,包括各个子系统的交互接口、对外开放接口、开发加密接口、接口文档等服务,可在该模块支持验签、鉴权、路由、限流、监控、容错、日志等功能。示例图:

![](https://s2.51cto.com/images/20210829/1630167608671975.jpg)

> zheng-cms

内容管理系统:支持多标签、多类目、强大评论的内容管理,有基本单页展示,菜单管理,系统设置等功能。

> zheng-pay

*   一站式支付解决方案,统一下单接口,支持支付宝、微信、网银等多种支付方式。不涉及业务的纯粹的支付平台。